日期:2014-05-16 浏览次数:20379 次
var aa = $("#id").val().trim()?? --- 在IE中无法解析trim() 方法 解决办法: [?? var aa = $.trim($("#id").val());? ]
?
这个不好用
,还是用下面介绍的吧,第一个已经过测试。 ?
实现1? OK? 的。(在js中写上这个,然后直接在你要去空格的字符串后面跟上 .trim() 即可) 1. String.prototype.trim = function () { 2.return this .replace(/^\s\s*/, '' ).replace(/\s\s*$/, '' ); 3. } 看起来不怎么样,动用了两次正则替换,实际速度很是惊人,主要得益于浏览器的内部优化。一个著名的例子字符串拼接,直接相加比用Array做成的StringBuffer还快。base2类库施用这种实现。 实现2 1. String.prototype.trim = function () { 2.return this .replace(/^\s /, '' ).replace(/\s $/, '' ); 3. } 和实现1很相似,但稍慢一点,主要原因是它最先是假设至少存在一个空白符。Prototype.js施用这种实现,不过其名儿为strip,因为Prototype的方法都是力图与Ruby重名。 实现3 1. String.prototype.trim = function () { 2.returnthis .substring(Math.max( this .search(/\S/), 0), this .search(/\S\s*$/) 1); 3. } 以截取方式取得空白部分(当然允许中间存在空白符),总共调用了4个原生方法。预设得很是巧妙,substring以两个数码作为参数。Math.max以两个数码作参数,search则归回一个数码。速度比上边两个慢一点,但比下面大大都都快。 实现4 1. String.prototype.trim = function () { 2.returnthis .replace(/^\s |\s $/g, '' ); 3. } 这个可以称得上实现2的简化版,就是利用候选操作符连接两个正则。但这样做就落空了浏览器优化的机会,比不上实现3。由于看来很优雅,许多类库都施用它,如JQuery与mootools 实现5 1. String.prototype.trim = function () { 2.var str = this ; 3.str = str.match(/\S (?:\s \S )*/); 4.return str ? str[0] : '' ; 5. } match是归回一个数组,是以原字符串切合要求的部分就成为它的元素。为了防止字符串中间的空白符被解除,咱们需要动用到非捕获性分组 (?:exp)。由于数组可能为空,咱们在后面还要做进一步的判定。好像浏览器在处理分组上比力无力,一个字慢。所以不要迷信正则,虽然它基本上是万能 的。 实现6 1. String.prototype.trim = function () { 2.return this .replace(/^\s*(\S*(\s \S )*)\s*$/, '$1' ); 3. } 把切合要求的部分提供出来,放到一个空字符串中。不过效率很差,尤其是在IE6中。 实现7 1. String.prototype.trim = function () { 2.return this .replace(/^\s*(\S*(?:\s \S )*)\s*$/, '$1' ); 3. }