JavaScript中的trim自定義
阿新 • • 發佈:2017-10-21
代碼 原型 div console 字符串 class 位或 color bstr
先直接貼代碼
1 String.prototype.trimfy=function (val){ 2 var demo=String(this); 3 if(demo.indexOf(val)>=0){ 4 if(demo.substring(demo.indexOf(val),val.length)===val){ 5 demo=demo.substring(demo.indexOf(val)+val.length); 6 }7 } 8 if(demo.lastIndexOf(val)>=0){ 9 if(demo.substring(demo.lastIndexOf(val))===val){ 10 demo=demo.slice(0,demo.lastIndexOf(val)); 11 } 12 } 13 if(demo.indexOf(val)==0||demo.lastIndexOf(val)==0){ 14 demo= demo.trimfy(val);15 } 16 return demo; 17 }
調用方法
console.log("前"+"aaba".trimfy("a")+"後")
console.log("前"+"aaba".trimfy("aa")+"後")
首先這個方法時擴展到了String原型上,判斷邏輯也比較簡單,清除indexOf和lastIndexOf等於0的字符串並保留剩下的部分,再使用遞歸方式找到最終的字符串。
如果想只清除首位或者末尾的字符串 方法可以繼續擴展,此處不在說明
JavaScript中的trim自定義