zoukankan      html  css  js  c++  java
  • js去除空格12种方法


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


      1 //JS去除空格的方法目前共有12种:
      2 //实现1
      3  String.prototype.trim = function() {
      4    return this.replace(/^ss*/, '').replace(/ss*$/, '');
      5  }
      6 //看起来不怎么样, 动用了两次正则替换,实际速度非常惊人,主要得益于浏览器的内部优化。一个著名的例子字符串拼接,直接相加比用Array做成的StringBuffer 还快。base2类库使用这种实现。
      7 // 实现2
      8  String.prototype.trim = function() {
      9    return this.replace(/^s+/, '').replace(/s+$/, '');
     10  }
     11 //和实现1 很相似,但稍慢一点,主要原因是它最先是假设至少存在一个空白符。Prototype.js使用这种实现,过其名字为strip,因为 Prototype的方法都是力求与Ruby同名。
     12  实现3
     13  String.prototype.trim = function() {
     14    return  this.substring(Math.max(this.search(/S/), 0),this.search(/Ss*$/) + 1);
     15  }
     16 //以截取方式取得空白部分(当然允许中间存在空白符),总共 调用了四个原生方法。设计得非常巧妙,substring以两个数字作为参数。Math.max以两个数字作参数,search则返回一个数字。速度比上 面两个慢一点,但比下面大多数都快。
     17 // 实现4
     18  String.prototype.trim = function() {
     19    return  this.replace(/^s+|s+$/g, '');
     20  }
     21 //这个可以称得上实现2的简化版,就是 利用候选操作符连接两个正则。但这样做就失去了浏览器优化的机会,比不上实现3。由于看来很优雅,许多类库都使用它,如JQuery与mootools
     22 //实现5
     23  String.prototype.trim = function() {
     24    var str = this;
     25    str = str.match(/S+(?:s+S+)*/);
     26    return str ? str[0] : '';
     27  }
     28 // match 是返回一个数组,因此原字符串符合要求的部分就成为它的元素。为了防止字符串中间的空白符被排除,我们需要动用到非捕获性分组(?:exp)。由于数组可 能为空,我们在后面还要做进一步的判定。好像浏览器在处理分组上比较无力,一个字慢。所以不要迷信正则,虽然它基本上是万能的。
     29 // 实现6
     30  String.prototype.trim = function() {
     31    return this.replace(/^s*(S*(s+S+)*)s*$/, '$1');
     32  }
     33 //把符合要求的部分提供出来,放到一个空字符串中。不过效率很差,尤其是在IE6中。
     34 // 实现7
     35  String.prototype.trim = function() {
     36    return this.replace(/^s*(S*(?:s+S+)*)s*$/, '$1');
     37  }
     38 //和实现6很相似,但用了非捕获分组进行了优点,性能效之有一点点提升。
     39 
     40 //实现8
     41  String.prototype.trim = function() {
     42    return this.replace(/^s*((?:[Ss]*S)?)s*$/, '$1');
     43  }
     44 //沿着上面两个的思路进行改进,动用了非捕获分组与字符集合,用?顶替了*,效果非常惊人。尤其在IE6中,可 以用疯狂来形容这次性能的提升,直接秒杀火狐。
     45 // 实现9
     46  String.prototype.trim = function() {
     47    return this.replace(/^s*([Ss]*?)s*$/, '$1');
     48  }
     49 //这次是用懒惰匹配 顶替非捕获分组,在火狐中得到改善,IE没有上次那么疯狂。
     50  实现10
     51  String.prototype.trim = function() {
     52    var str = this,
     53    whitespace = ' 
    
    	fx0bxa0u2000u2001u2002u2003u2004u2005u2006u2007u2008u2009u200au200bu2028u2029u3000';
     54    for (var i = 0,len = str.length; i < len; i++) {
     55      if (whitespace.indexOf(str.charAt(i)) === -1) {
     56        str = str.substring(i);
     57        break;
     58      }
     59    }
     60    for (i = str.length - 1; i >= 0; i--) {
     61      if (whitespace.indexOf(str.charAt(i)) === -1) {
     62        str = str.substring(0, i + 1);
     63        break;
     64      }
     65    }
     66   return whitespace.indexOf(str.charAt(0)) === -1 ? str : '';
     67  }
     68 //我 只想说,搞出这个的人已经不是用牛来形容,已是神一样的级别。它先是把可能的空白符全部列出来,在第一次遍历中砍掉前面的空白,第二次砍掉后面的空白。全 过程只用了indexOf与substring这个专门为处理字符串而生的原生方法,没有使用到正则。速度快得惊人,估计直逼上内部的二进制实现,并且在 IE与火狐(其他浏览器当然也毫无疑问)都有良好的表现。速度都是零毫秒级别的。
     69 // 实现11
     70 String.prototype.trim = function() {
     71    var str = this,
     72    str = str.replace(/^s+/, '');
     73    for (var i = str.length - 1; i >= 0; i--) {
     74      if (/S/.test(str.charAt(i))) {
     75        str = str.substring(0, i + 1);
     76        break;
     77      }
     78    }
     79    return str;
     80  }
     81 //实现10已经告诉我们普通的原生字符串截取方法是远胜于正则替换,虽然是复杂一点。但只要正则 不过于复杂,我们就可以利用浏览器对正则的优化,改善程序执行效率,如实现8在IE的表现。我想通常不会有人在项目中应用实现10,因为那个 whitespace 实现太长太难记了(当然如果你在打造一个类库,它绝对是首先)。实现11可谓其改进版,前面部分的空白由正则替换负责砍掉,后面用原生方法处理,效果不逊 于原版,但速度都是非常逆天。
     82 // 实现12
     83  String.prototype.trim = function() {
     84    var str = this,
     85    str = str.replace(/^ss*/, ''),
     86    ws = /s/,
     87    i = str.length;
     88    while (ws.test(str.charAt(--i)));
     89    return str.slice(0, i + 1);
     90  }
     91 //实现10与实现11在写法上更好的改进版,注意说的不是性能速 度,而是易记与使用上。和它的两个前辈都是零毫秒级别的,以后就用这个来工作与吓人。
     92 
      1 //1:去字符串前后空格:changeThing.replace(/(^s*)|(s*$)/g,'')
      2 //2:
      3 function  trm(e){
      4       return e.replace( /^s+/, "" ).replace( /s+$/, "" ); //js去掉全换空格
      5      }
      6 //  调用:
      7  var  causeCheckNopass=trm(mini.get("m_zjhms").getValue());
      8 
      9 
     10 ==================================================================================================
     11 
     12 //1、  去掉字符串前后所有空格:
     13 //代码如下:
     14          function Trim(str)
     15          {   16              return str.replace(/(^s*)|(s*$)/g, "");   17      }
     18 //    说明:
     19 //    如果使用jQuery直接使用$.trim(str)方法即可,str表示要去掉前后所有空格的字符串。
     20    21 //2、 去掉字符串中所有空格(包括中间空格,需要设置第2个参数为:g)
     22 //代码如下:
     23         function Trim(str,is_global)
     24         {
     25             var result;
     26             result = str.replace(/(^s+)|(s+$)/g,"");
     27             if(is_global.toLowerCase()=="g")
     28             {
     29                 result = result.replace(/s/g,"");
     30              }
     31             return result;
     32 }
     33 
     34 ==================================================================================================
     35 
     36 //js去掉字符串前后空格的五种方法2012-04-02 
     37 
     38 [javascript]
     39 //供使用者调用  
     40 function trim(s){    41 return trimRight(trimLeft(s));    42 }    43 //去掉左边的空白  
     44 function trimLeft(s){    45 if(s == null) {    46 return "";    47 }    48 var whitespace = new String(" 	
    
    ");    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   
     60 function trimRight(s){    61 if(s == null) return "";    62 var whitespace = new String(" 	
    
    ");    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 第二种:正则替换
     74 [javascript]
     75 <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 //-->  
     90 </SCRIPT>   91 第三种:使用jquery
     92 [javascript]
     93 $.trim(str)   94 jquery内部实现为:
     95 [javascript]
     96 function trim(str){     97     return str.replace(/^(s|u00A0)+/,'').replace(/(s|u00A0)+$/,'');     98 }     99 第四种:使用motools
    100 [javascript]
    101 function trim(str){    102     return str.replace(/^(s|xA0)+|(s|xA0)+$/g, '');    103 }   104 第五种:裁剪字符串方式
    105 [javascript]
    106 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;    115116 }
    117 
    118 ==================================================================================================
    119 
    120 判断空:
    121  Object.prototype.toString。对于不同类型的数据,这个方法可以返回 '[object Object]'、'[object Array]'、'[object String]' 这样的字符串,非常方便判断。需要注意的是,在 IE8 及其以下浏览器中,这个方法对于null、undefined、window 等都会返回 '[object Object]',不过还好,这并不影响我们使用它判断空对象
    122 
    123 var isEmptyValue = function(value) {
    124             var type;
    125             if(value == null) { // 等同于 value === undefined || value === null
    126                 return true;
    127             }
    128             type = Object.prototype.toString.call(value).slice(8, -1);
    129             switch(type) {
    130             case 'String':
    131                 return !$.trim(value);
    132             case 'Array':
    133                 return !value.length;
    134             case 'Object':
    135                 return $.isEmptyObject(value); // 普通对象使用 for...in 判断,有 key 即为 false
    136             default:
    137                 return false; // 其他对象均视作非空
    138             }
    139         };
    140 
    141 为何不用其他方法,因为下面的写法考虑了各种兼容性。
    142 判断是否为数组
    143 isArray = function (source) {
    144     return '[object Array]' == Object.prototype.toString.call(source);
    145 };
    146 判断是否为日期对象
    147 isDate = function(o) {
    148     // return o instanceof Date;
    149     return {}.toString.call(o) === "[object Date]" && o.toString() !== 'Invalid Date' && !isNaN(o);
    150 };
    151 判断是否为Element对象
    152 isElement = function (source) {
    153     return !!(source && source.nodeName && source.nodeType == 1);
    154 };
    155 判断目标参数是否为function或Function实例
    156 isFunction = function (source) {
    157     // chrome下,'function' == typeof /a/ 为true.
    158     return '[object Function]' == Object.prototype.toString.call(source);
    159 };
    160 判断目标参数是否number类型或Number对象
    161 isNumber = function (source) {
    162     return '[object Number]' == Object.prototype.toString.call(source) && isFinite(source);
    163 };
    164  判断目标参数是否为Object对象
    165 isObject = function (source) {
    166     return 'function' == typeof source || !!(source && 'object' == typeof source);
    167 };
    168 判断目标参数是否string类型或String对象
    169 isString = function (source) {
    170     return '[object String]' == Object.prototype.toString.call(source);
    171 };
    172 判断目标参数是否Boolean对象
    173 isBoolean = function(o) {
    174     return typeof o === 'boolean';
    175 };
    176 
    177 
    178 1、  去掉字符串前后所有空格:
    179 代码如下:
    180          function Trim(str)
    181          {  182              return str.replace(/(^s*)|(s*$)/g, "");  183      }
    184     说明:
    185     如果使用jQuery直接使用$.trim(str)方法即可,str表示要去掉前后所有空格的字符串。
    186   187 2、 去掉字符串中所有空格(包括中间空格,需要设置第2个参数为:g)
    188 代码如下:
    189         function Trim(str,is_global)
    190         {
    191             var result;
    192             result = str.replace(/(^s+)|(s+$)/g,"");
    193             if(is_global.toLowerCase()=="g")
    194             {
    195                 result = result.replace(/s/g,"");
    196              }
    197             return result;
    198 }
    199 
    200 ==================================================================================================
    201 js去除输入框中所有的空格和禁止输入空格的方法
    202 <span style="font-family: Arial, Helvetica, sans-serif;">
    203       <input type="password" name="password" id="password" onkeydown="return banInputSapce(event);" onKeyup="return inputSapceTrim(event,this);" />
    204 </span>  205 
    206 /**  207 * 是否去除所有空格  208 * @param str  209 * @param is_global 如果为g或者G去除所有的  210 * @returns  211 */  212 function Trim(str,is_global)  213214 var result;  215 result = str.replace(/(^s+)|(s+$)/g,"");  216 if(is_global.toLowerCase()=="g")  217218 result = result.replace(/s/g,"");  219220 return result;  221222 
    223 /**  224 * 空格输入去除  225 * @param e  226 * @returns {Boolean}  227 */  228 function inputSapceTrim(e,this_temp)  229230 this_temp.value = Trim(this_temp.value,"g");  231 var keynum;  232 if(window.event) // IE 
    233234 keynum = e.keyCode  235236 else if(e.which) // Netscape/Firefox/Opera 
    237238 keynum = e.which  239240 if(keynum == 32){  241 return false242243 return true244245 /**  246 * 禁止空格输入  247 * @param e  248 * @returns {Boolean}  249 */  250 function banInputSapce(e)  251252 var keynum;  253 if(window.event) // IE 
    254255 keynum = e.keyCode  256257 else if(e.which) // Netscape/Firefox/Opera 
    258259 keynum = e.which  260261 if(keynum == 32){  262 return false263264 return true265266 
    267 
    268 
    269 
    270 

    ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

  • 相关阅读:
    openjudge666:放苹果—题解
    欢迎来到路由器的世界!这里是开端
    Codevs1169:传纸条——题解
    POJ3498:March of the Penguins——题解
    模板:并查集
    模板:快速幂
    模板:排序(三)
    程序员之间的鄙视链
    自动化测试的成本高效果差,那么自动化测试的意义在哪呢
    自动化测试的成本高效果差,那么自动化测试的意义在哪呢
  • 原文地址:https://www.cnblogs.com/ios9/p/7680923.html
Copyright © 2011-2022 走看看