我试图找到一种方法来修剪标题字符串开头和结尾的空格。我正在使用它,但它似乎不起作用:
title = title.replace(/(^[\s]+|[\s]+$)/g, '');
有任何想法吗?
我试图找到一种方法来修剪标题字符串开头和结尾的空格。我正在使用它,但它似乎不起作用:
title = title.replace(/(^[\s]+|[\s]+$)/g, '');
有任何想法吗?
注意:截至 2015 年,所有主流浏览器(包括 IE>=9)都支持 String.prototype.trim()。这意味着对于大多数用例,简单地做str.trim()
是实现问题的最佳方式。
Steven Levithantrim
在性能方面分析了Javascript 中的许多不同实现。
他的建议是:
function trim1 (str) {
return str.replace(/^\s\s*/, '').replace(/\s\s*$/, '');
}
对于“快速跨浏览器的通用实现”,以及
function trim11 (str) {
str = str.replace(/^\s+/, '');
for (var i = str.length - 1; i >= 0; i--) {
if (/\S/.test(str.charAt(i))) {
str = str.substring(0, i + 1);
break;
}
}
return str;
}
“如果你想在所有浏览器中以异常快的速度处理长字符串”。
如果使用 jQuery 是一种选择:
/**
* Trim the site input[type=text] fields globally by removing any whitespace from the
* beginning and end of a string on input .blur()
*/
$('input[type=text]').blur(function(){
$(this).val($.trim($(this).val()));
});
或者干脆:
$.trim(string);
正如@ChaosPandion提到的,该String.prototype.trim
方法已经被引入到ECMAScript 5th Edition Specification 中,一些实现已经包含这个方法,所以最好的方法是检测本机实现并只有在它不可用时才声明它:
if (typeof String.prototype.trim != 'function') { // detect native implementation
String.prototype.trim = function () {
return this.replace(/^\s+/, '').replace(/\s+$/, '');
};
}
然后你可以简单地:
title = title.trim();
我知道这是一个旧帖子,但只是想我会分享我们的解决方案。为了寻求最短的代码(不是每个人都喜欢简洁的正则表达式),可以改为使用:
title = title.replace(/(^\s+|\s+$)/g, '');
顺便说一句:我通过blog.stevenlevithan.com上面共享的链接进行了同样的测试——更快的 JavaScript Trim和这种模式击败了所有其他人!
使用IE8,添加测试为test13。结果是:
原始长度:226002
trim1:110ms(长度:225994)
trim2:79ms(长度:225994)
trim3:172ms(长度:225994)
trim4:203ms(长度:225994)
trim5:172ms(长度:9412)
trim2:172ms(长度:225994)trim3:203ms(长度:225994)225994)
trim7:203ms(长度:225994)
trim8:47ms(长度:225994)
trim9:453ms(长度:225994)
trim10:15ms(长度:225994)
trim11:16ms(长度:43255)
trim22
修剪 13:0 毫秒(长度:226002)
ECMAScript 5 支持trim
并且这已在 Firefox 中实现。