欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

js去除空格12种方法

程序员文章站 2022-04-15 13:56:17
注:本文非本人原著;原文作者: 黄卉 《js去除空格12种方法》 ......

注:本文非本人原著;原文作者:   《js去除空格12种方法

//js去除空格的方法目前共有12种:
//实现1
 string.prototype.trim = function() {
   return this.replace(/^\s\s*/, '').replace(/\s\s*$/, '');
 }
//看起来不怎么样, 动用了两次正则替换,实际速度非常惊人,主要得益于浏览器的内部优化。一个著名的例子字符串拼接,直接相加比用array做成的stringbuffer 还快。base2类库使用这种实现。
// 实现2
 string.prototype.trim = function() {
   return this.replace(/^\s+/, '').replace(/\s+$/, '');
 }
//和实现1 很相似,但稍慢一点,主要原因是它最先是假设至少存在一个空白符。prototype.js使用这种实现,过其名字为strip,因为 prototype的方法都是力求与ruby同名。
 实现3
 string.prototype.trim = function() {
   return  this.substring(math.max(this.search(/\s/), 0),this.search(/\s\s*$/) + 1);
 }
//以截取方式取得空白部分(当然允许中间存在空白符),总共 调用了四个原生方法。设计得非常巧妙,substring以两个数字作为参数。math.max以两个数字作参数,search则返回一个数字。速度比上 面两个慢一点,但比下面大多数都快。
// 实现4
 string.prototype.trim = function() {
   return  this.replace(/^\s+|\s+$/g, '');
 }
//这个可以称得上实现2的简化版,就是 利用候选操作符连接两个正则。但这样做就失去了浏览器优化的机会,比不上实现3。由于看来很优雅,许多类库都使用它,如jquery与mootools
//实现5
 string.prototype.trim = function() {
   var str = this;
   str = str.match(/\s+(?:\s+\s+)*/);
   return str ? str[0] : '';
 }
// match 是返回一个数组,因此原字符串符合要求的部分就成为它的元素。为了防止字符串中间的空白符被排除,我们需要动用到非捕获性分组(?:exp)。由于数组可 能为空,我们在后面还要做进一步的判定。好像浏览器在处理分组上比较无力,一个字慢。所以不要迷信正则,虽然它基本上是万能的。
// 实现6
 string.prototype.trim = function() {
   return this.replace(/^\s*(\s*(\s+\s+)*)\s*$/, '$1');
 }
//把符合要求的部分提供出来,放到一个空字符串中。不过效率很差,尤其是在ie6中。
// 实现7
 string.prototype.trim = function() {
   return this.replace(/^\s*(\s*(?:\s+\s+)*)\s*$/, '$1');
 }
//和实现6很相似,但用了非捕获分组进行了优点,性能效之有一点点提升。

//实现8
 string.prototype.trim = function() {
   return this.replace(/^\s*((?:[\s\s]*\s)?)\s*$/, '$1');
 }
//沿着上面两个的思路进行改进,动用了非捕获分组与字符集合,用?顶替了*,效果非常惊人。尤其在ie6中,可 以用疯狂来形容这次性能的提升,直接秒杀火狐。
// 实现9
 string.prototype.trim = function() {
   return this.replace(/^\s*([\s\s]*?)\s*$/, '$1');
 }
//这次是用懒惰匹配 顶替非捕获分组,在火狐中得到改善,ie没有上次那么疯狂。
 实现10
 string.prototype.trim = function() {
   var str = this,
   whitespace = ' \n\r\t\f\x0b\xa0\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u200b\u2028\u2029\u3000';
   for (var i = 0,len = str.length; i < len; i++) {
     if (whitespace.indexof(str.charat(i)) === -1) {
       str = str.substring(i);
       break;
     }
   }
   for (i = str.length - 1; i >= 0; i--) {
     if (whitespace.indexof(str.charat(i)) === -1) {
       str = str.substring(0, i + 1);
       break;
     }
   }
  return whitespace.indexof(str.charat(0)) === -1 ? str : '';
 }
//我 只想说,搞出这个的人已经不是用牛来形容,已是神一样的级别。它先是把可能的空白符全部列出来,在第一次遍历中砍掉前面的空白,第二次砍掉后面的空白。全 过程只用了indexof与substring这个专门为处理字符串而生的原生方法,没有使用到正则。速度快得惊人,估计直逼上内部的二进制实现,并且在 ie与火狐(其他浏览器当然也毫无疑问)都有良好的表现。速度都是零毫秒级别的。
// 实现11
string.prototype.trim = function() {
   var str = this,
   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;
 }
//实现10已经告诉我们普通的原生字符串截取方法是远胜于正则替换,虽然是复杂一点。但只要正则 不过于复杂,我们就可以利用浏览器对正则的优化,改善程序执行效率,如实现8在ie的表现。我想通常不会有人在项目中应用实现10,因为那个 whitespace 实现太长太难记了(当然如果你在打造一个类库,它绝对是首先)。实现11可谓其改进版,前面部分的空白由正则替换负责砍掉,后面用原生方法处理,效果不逊 于原版,但速度都是非常逆天。
// 实现12
 string.prototype.trim = function() {
   var str = this,
   str = str.replace(/^\s\s*/, ''),
   ws = /\s/,
   i = str.length;
   while (ws.test(str.charat(--i)));
   return str.slice(0, i + 1);
 }
//实现10与实现11在写法上更好的改进版,注意说的不是性能速 度,而是易记与使用上。和它的两个前辈都是零毫秒级别的,以后就用这个来工作与吓人。

  

//1:去字符串前后空格:changething.replace(/(^\s*)|(\s*$)/g,'')
//2:
function  trm(e){
      return e.replace( /^\s+/, "" ).replace( /\s+$/, "" ); //js去掉全换空格
     }
//  调用:
 var  causechecknopass=trm(mini.get("m_zjhms").getvalue());


==================================================================================================

//1、  去掉字符串前后所有空格:
//代码如下:
         function trim(str)
         {   16              return str.replace(/(^\s*)|(\s*$)/g, "");   17      }
//    说明:
//    如果使用jquery直接使用$.trim(str)方法即可,str表示要去掉前后所有空格的字符串。
   21 //2、 去掉字符串中所有空格(包括中间空格,需要设置第2个参数为:g)
//代码如下:
        function trim(str,is_global)
        {
            var result;
            result = str.replace(/(^\s+)|(\s+$)/g,"");
            if(is_global.tolowercase()=="g")
            {
                result = result.replace(/\s/g,"");
             }
            return result;
}

==================================================================================================

//js去掉字符串前后空格的五种方法2012-04-02 

[javascript]
//供使用者调用  
function trim(s){    41 return trimright(trimleft(s));    42 }    43 //去掉左边的空白  
function trimleft(s){    45 if(s == null) {    46 return "";    47 }    48 var whitespace = new string(" \t\n\r");    49 var str = new string(s);    50 if (whitespace.indexof(str.charat(0)) != -1) {    51 var j=0, i = str.length;    52 while (j < i && whitespace.indexof(str.charat(j)) != -1){    53 j++;    54 }    55 str = str.substring(j, i);    56 }    57 return str;    58 }    59 //去掉右边的空白 www.2cto.com   
function trimright(s){    61 if(s == null) return "";    62 var whitespace = new string(" \t\n\r");    63 var str = new string(s);    64 if (whitespace.indexof(str.charat(str.length-1)) != -1){    65 var i = str.length - 1;    66 while (i >= 0 && whitespace.indexof(str.charat(i)) != -1){    67 i--;    68 }    69 str = str.substring(0, i+1);    70 }    71 return str;    72 }   73 第二种:正则替换
[javascript]
<script language="javascript">    76 <!--    77 string.prototype.trim = function()    78 {    79 return this.replace(/(^\s*)|(\s*$)/g, "");    80 }    81 string.prototype.ltrim = function()    82 {    83 return this.replace(/(^\s*)/g, "");    84 }    85 string.prototype.rtrim = function()    86 {    87 return this.replace(/(\s*$)/g, "");    88 }    89 //-->  
</script>   91 第三种:使用jquery
[javascript]
$.trim(str)   94 jquery内部实现为:
[javascript]
function trim(str){     97     return str.replace(/^(\s|\u00a0)+/,'').replace(/(\s|\u00a0)+$/,'');     98 }     99 第四种:使用motools
[javascript]
function trim(str){    102     return str.replace(/^(\s|\xa0)+|(\s|\xa0)+$/g, '');    103 }   104 第五种:裁剪字符串方式
[javascript]
function trim(str){    107     str = str.replace(/^(\s|\u00a0)+/,'');    108     for(var i=str.length-1; i>=0; i--){    109         if(/\s/.test(str.charat(i))){    110             str = str.substring(0, i+1);    111             break;    112         }    113     }    114     return str;    115 }  116 }

==================================================================================================

判断空:
 object.prototype.tostring。对于不同类型的数据,这个方法可以返回 '[object object]'、'[object array]'、'[object string]' 这样的字符串,非常方便判断。需要注意的是,在 ie8 及其以下浏览器中,这个方法对于null、undefined、window 等都会返回 '[object object]',不过还好,这并不影响我们使用它判断空对象

var isemptyvalue = function(value) {
            var type;
            if(value == null) { // 等同于 value === undefined || value === null
                return true;
            }
            type = object.prototype.tostring.call(value).slice(8, -1);
            switch(type) {
            case 'string':
                return !$.trim(value);
            case 'array':
                return !value.length;
            case 'object':
                return $.isemptyobject(value); // 普通对象使用 for...in 判断,有 key 即为 false
            default:
                return false; // 其他对象均视作非空
            }
        };

为何不用其他方法,因为下面的写法考虑了各种兼容性。
判断是否为数组
isarray = function (source) {
    return '[object array]' == object.prototype.tostring.call(source);
};
判断是否为日期对象
isdate = function(o) {
    // return o instanceof date;
    return {}.tostring.call(o) === "[object date]" && o.tostring() !== 'invalid date' && !isnan(o);
};
判断是否为element对象
iselement = function (source) {
    return !!(source && source.nodename && source.nodetype == 1);
};
判断目标参数是否为function或function实例
isfunction = function (source) {
    // chrome下,'function' == typeof /a/ 为true.
    return '[object function]' == object.prototype.tostring.call(source);
};
判断目标参数是否number类型或number对象
isnumber = function (source) {
    return '[object number]' == object.prototype.tostring.call(source) && isfinite(source);
};
 判断目标参数是否为object对象
isobject = function (source) {
    return 'function' == typeof source || !!(source && 'object' == typeof source);
};
判断目标参数是否string类型或string对象
isstring = function (source) {
    return '[object string]' == object.prototype.tostring.call(source);
};
判断目标参数是否boolean对象
isboolean = function(o) {
    return typeof o === 'boolean';
};


1、  去掉字符串前后所有空格:
代码如下:
         function trim(str)
         {  182              return str.replace(/(^\s*)|(\s*$)/g, "");  183      }
    说明:
    如果使用jquery直接使用$.trim(str)方法即可,str表示要去掉前后所有空格的字符串。
  187 2、 去掉字符串中所有空格(包括中间空格,需要设置第2个参数为:g)
代码如下:
        function trim(str,is_global)
        {
            var result;
            result = str.replace(/(^\s+)|(\s+$)/g,"");
            if(is_global.tolowercase()=="g")
            {
                result = result.replace(/\s/g,"");
             }
            return result;
}

==================================================================================================
js去除输入框中所有的空格和禁止输入空格的方法
<span style="font-family: arial, helvetica, sans-serif;">
      <input type="password" name="password" id="password" onkeydown="return baninputsapce(event);" onkeyup="return inputsapcetrim(event,this);" />
</span>  205 
/**  207 * 是否去除所有空格  208 * @param str  209 * @param is_global 如果为g或者g去除所有的  210 * @returns  211 */  212 function trim(str,is_global)  213 {  214 var result;  215 result = str.replace(/(^\s+)|(\s+$)/g,"");  216 if(is_global.tolowercase()=="g")  217 {  218 result = result.replace(/\s/g,"");  219 }  220 return result;  221 }  222 
/**  224 * 空格输入去除  225 * @param e  226 * @returns {boolean}  227 */  228 function inputsapcetrim(e,this_temp)  229 {  230 this_temp.value = trim(this_temp.value,"g");  231 var keynum;  232 if(window.event) // ie 
{  234 keynum = e.keycode  235 }  236 else if(e.which) // netscape/firefox/opera 
{  238 keynum = e.which  239 }  240 if(keynum == 32){  241 return false;  242 }  243 return true;  244 }  245 /**  246 * 禁止空格输入  247 * @param e  248 * @returns {boolean}  249 */  250 function baninputsapce(e)  251 {  252 var keynum;  253 if(window.event) // ie 
{  255 keynum = e.keycode  256 }  257 else if(e.which) // netscape/firefox/opera 
{  259 keynum = e.which  260 }  261 if(keynum == 32){  262 return false;  263 }  264 return true;  265 }  266