1. 程式人生 > 程式設計 >js String.prototype.trim字元去前後空格的擴充套件

js String.prototype.trim字元去前後空格的擴充套件

最近學習js的時候發現的這個函式,這樣很方便地去除前後空格,用正則實現,簡單方便。下面我們小編就為大家分享一下幾種實現方式。

String.Prototype.trim()

trim()返回一個字串兩端空白字元被刪除的新字串,不影響原字串。

第一種實現方式:理論上算是比較不錯的

if (!String.prototype.trim) {
 String.prototype.trim = function () {
  return this.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,'');
 };
}

第二種實現方式

 String.prototype.trim = function(a) {
  var b = (this + "").replace(/(^[ \t\n\r\f\x0b\xa0]*)|([ \t\n\r\f\x0b\xa0]*$)/g,"");
  a && (a = (a + "").replace(/([\[\]\(\)\.\?\/\*\{\}\+\$\^\:])/g,"\\$1"),b = b.replace(new RegExp("(^[" + a + "]*)|([" + a + "]*$)","g"),""));
  return b
};

第三種、範圍有點小,推薦學習,不推薦使用

String.prototype.trim = function(){   
   //用正則表示式將前後空格用空字串替代。   
   return  this.replace(/(^\s*)|(\s*$)/g,"");   
  } 

今天呢 知乎看到一道題 說是網易面試題,要求自己寫一個trim()方法,

實現 var str = " a sd "; 去掉字串兩端的空格。

直接上碼

var str = "  a sd ";
 
 function trim (st) {
  // 先把字串分割成陣列
  var arr = st.split("");
  // 從前面刪除空格
  for (let i = 0; i < arr.length; i++) {
   // 如果陣列元素是空格則刪除
   if (arr[i] === " ") {
    arr.shift();
    /*console.log(arr.length,i)*/
    // 如果當前元素的下一項不是空格退出迴圈
    if (arr[i+1] !== " ") {
     break;
    }
        
   }
  }
  // 後前面刪除空格
  for (let i = arr.length; i >= 0; i--) {
   // 如果陣列元素是空格則刪除
   if (arr[i-1] === " ") {
    arr.pop();
    // 如果當前元素的前一項不是空格退出迴圈
    if (arr[i-2] !== " ") {
     break;
    }
   }
  }
  arr = arr.join("");
  /*console.log(arr);*/
  return arr;
 }
 var a = trim(str);
 console.log(a); //a sd//

原理註釋寫的很清楚

不用正則實現的程式碼

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; 
} 
function delrd(str){
var reg=/,$/gi; 
str=str.replace(reg,"");
return str;
}

以上就是js String.prototype.trim字元去前後空格的擴充套件的詳細內容,更多關於String物件增加一個trim方法的資料請關注我們其它相關文章!