js trim函數 去空格函數與正則集錦

在javascript中處理文本框輸入值的時候,常常要用到"去掉先後空白"的功能。用過jQuery的朋友都知道,jQuery提供了一個trim()這樣的功能函數,能夠很輕鬆幫咱們實現這樣的效果。
 
可是若是項目沒有用到jQuery等框架的話,js自己又沒有這樣的函數,咱們不得不本身寫這樣的函數,下面是函數的具體實現: 
複製代碼代碼以下:

//供使用者調用 
function trim(s){ 
return trimRight(trimLeft(s)); 

//去掉左邊的空白 
function trimLeft(s){ 
if(s == null) { 
return ""; 

var whitespace = new String(" \t\n\r"); 
var str = new String(s); 
if (whitespace.indexOf(str.charAt(0)) != -1) { 
var j=0, i = str.length; 
while (j < i && whitespace.indexOf(str.charAt(j)) != -1){ 
j++; 

str = str.substring(j, i); 

return str; 

//去掉右邊的空白 
function trimRight(s){ 
if(s == null) return ""; 
var whitespace = new String(" \t\n\r"); 
var str = new String(s); 
if (whitespace.indexOf(str.charAt(str.length-1)) != -1){ 
var i = str.length - 1; 
while (i >= 0 && whitespace.indexOf(str.charAt(i)) != -1){ 
i--; 

str = str.substring(0, i+1); 

return str; 

使用時只需調用trim函數便可。 
下面是用正則的實現方法: 
複製代碼代碼以下:
<SCRIPT LANGUAGE="JavaScript">  <!--  String.prototype.Trim = function()  {  return this.replace(/(^\s*)|(\s*$)/g, "");  }  String.prototype.LTrim = function()  {  return this.replace(/(^\s*)/g, "");  }  String.prototype.RTrim = function()  {  return this.replace(/(\s*$)/g, "");  }  //-->  </SCRIPT>  <input type="text" value="    先後都是空格   " id="space">  <input type="button" value="去先後空格" onclick="javascript:document.getElementById('space').value=document.getElementById('space').value.Trim();document.getElementById('space').select();">  <input type="button" value="去前空格" onclick="javascript:document.getElementById('space').value=document.getElementById('space').value.LTrim();document.getElementById('space').select();">  <input type="button" value="去後空格" onclick="javascript:document.getElementById('space').value=document.getElementById('space').value.RTrim();document.getElementById('space').select();">  <input type="button" value="還原" onclick="javascript:document.getElementById('space').value='    先後都是空格     ';"> 
相關文章
相關標籤/搜索