String对象增加一个trim方法 js String.prototype.trim字符去前后空格的扩展
人气:2最近学习js的时候发现的这个函数,这样很方便地去除前后空格,用正则实现,简单方便。下面小编就为大家分享一下几种实现方式。
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)*/ // 如果当前元素的下一项不是空格退出循环 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; }
加载全部内容