欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js String.prototype.trim字符去前后空格的擴展

 更新時間:2020年08月23日 23:21:40   投稿:mdxy-dxy  
這篇文章主要介紹了js String.prototype.trim字符去前后空格的擴展,需要的朋友可以參考下

最近學習js的時候發(fā)現的這個函數,這樣很方便地去除前后空格,用正則實現,簡單方便。下面腳本之家小編就為大家分享一下幾種實現方式。

String.Prototype.trim()

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

/*內置對象添加方法:String.prototype.trim(給String添加一個trim方法)
*^這個是以什么什么開頭
*$這個是以什么什么結尾
*‘/s是String /d是數字'
*replace(/^\s+/ , "")把以字符開頭的字符串替換為空字符串,
*replace(/\s+$/ , "")把以字符結尾的字符串替換為空字符串,
*/

String.prototype.trim = function(){
return this.replace(/^\s+/ , "").replace(/\s+$/ , "");
}

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

具體的可以查看這篇文章:

https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/String/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,""); 
 } 

第四種,不用正則實現

var str = " ac c ";
//使用String prototype 給用添加自定義方法。
String.prototype.trim = function(){
 var start = 0;
 var end = code.length-1;
 while(start<=end && this.charAt(start) == ' '){
	start++;
 }
 while(start<=end && this.charAt(end) == ' '){
	end--;
 }
 //使用字符截取指定字符
 return this.substring(start,end+1);
 };
 //使用原型直接調用
 console.log("--"+str.trim()+"--")

推薦使用第一種、第二種方法。

下面是其他網友的補充,大家可以參考一下

今天呢 知乎看到一道題 說是網易面試題,要求自己寫一個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)*/
 // 如果當前元素的下一項不是空格退出循環(huán)
 if (arr[i+1] !== " ") {
 break;
 }
 
 }
 }
 // 后前面刪除空格
 for (let i = arr.length; i >= 0; i--) {
 // 如果數組元素是空格則刪除
 if (arr[i-1] === " ") {
 arr.pop();
 // 如果當前元素的前一項不是空格退出循環(huán)
 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方法的資料請關注腳本之家其它相關文章!

相關文章

  • 正則表達式替換html元素屬性的方法

    正則表達式替換html元素屬性的方法

    下面小編就為大家?guī)硪黄齽t表達式替換html元素屬性的方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-11-11
  • 基于mpvue小程序使用echarts畫折線圖的方法示例

    基于mpvue小程序使用echarts畫折線圖的方法示例

    這篇文章主要介紹了基于mpvue小程序使用echarts畫折線圖的方法示例,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-04-04
  • 原生js實現jquery函數animate()動畫效果的簡單實例

    原生js實現jquery函數animate()動畫效果的簡單實例

    下面小編就為大家?guī)硪黄鷍s實現jquery函數animate()動畫效果的簡單實例。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08
  • javascript:window.open彈出窗口的位置問題

    javascript:window.open彈出窗口的位置問題

    這篇文章主要介紹了javascript:window.open彈出窗口的位置問題,需要的朋友可以參考下
    2014-03-03
  • 淺談JavaScript中this的指向問題

    淺談JavaScript中this的指向問題

    這篇文章主要介紹了淺談JavaScript中this的指向問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • Bootstrap學習筆記之環(huán)境配置(1)

    Bootstrap學習筆記之環(huán)境配置(1)

    這篇文章主要為大家詳細介紹了Bootstrap學習筆記之環(huán)境配置的具體操作方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • javascript 精確獲取樣式屬性(上)

    javascript 精確獲取樣式屬性(上)

    設置與獲取樣式屬性是UI控件與特效庫非常關鍵的部分,設置樣式我們基本可以用cssText來包打天下,但獲取樣式就不是這回事了。
    2010-01-01
  • 詳解TypeScript編譯TSX文件的方法

    詳解TypeScript編譯TSX文件的方法

    因為使用 Cycle.js 的 Vite + TSX 所以想詳細的探索 TSX 在 TS 配置中的編譯情況,本文主要講解 tsconfig 和 tsx 編譯與配置,以常見的框架 PReact 的虛擬 DOM + TSX 組合、snabbdom + TSX 組合不同的配置以及編譯輸出
    2023-09-09
  • js實現圖片點擊左右輪播

    js實現圖片點擊左右輪播

    本文給大家分享的是使用javascript實現的圖片左右輪播的代碼,已經封裝完畢,使用方法非常簡單,參考示例,有需要的小伙伴可以參考下。
    2015-07-07
  • js實現HashTable(哈希表)的實例分析

    js實現HashTable(哈希表)的實例分析

    本文詳細介紹javascript哈希表的實例分析及用法。下面就跟小編一起來學習下吧
    2016-11-11

最新評論