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

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

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

js去除空格12种方法的更多相关文章

  1. js去除空格(trim方法)

    /** * 去空格 */ String.prototype.trim=function(){ return this.replace(/(^\s*)|(\s*$)/g, ""); ...

  2. js去除空格,判断是否包含

    js去除空格 function trimStr(str){ return str.replace(/(^\s*)|(\s*$)/g,""); } js判断是否包含 //是否包含 f ...

  3. 判断数组的方法/判断JS数据类型的四种方法

    参考文: 以下 3 个判断数组的方法,请分别介绍它们之间的区别和优劣Object.prototype.toString.call() . instanceof 以及 Array.isArray() h ...

  4. JS去除空格方法记录

    JS中去掉空格 //去除空格  String.prototype.Trim = function() {      return this.replace(/\s+/g, ""); ...

  5. js 去掉字符串前后空格5种方法

    第一种:循环检查替换 //供使用者调用 function trim(s){ return trimRight(trimLeft(s)); } //去掉左边的空白 function trimLeft(s ...

  6. JS清除空格之trim()方法

    JQ: $.trim() 函数用于去除字符串两端的空白字符. 注意:$.trim()函数会移除字符串开始和末尾处的所有换行符,空格(包括连续的空格)和制表符.如果这些空白字符在字符串中间时,它们将被保 ...

  7. js 小工具-- 原生 js 去除空格

    // 原生js 去除字符串空格 <script type="text/javascript"> String.prototype.trim = function (){ ...

  8. 动态加载JS脚本的4种方法

    实现OPOA(One Page One Application)时,必须使用动态加载js. 也就是在用户选择某个菜单项后,再动态加载对应的全部js到客户端. 动态加载js的情况很多啊,比如解决ajax ...

  9. OC和JS交互的三种方法

    看简书上说一共有六种OC和JS交互的方法,但是前三种原理都一致,都是通过检测.拦截Url地址实现互相调用的.剩下的react native等第三方框架原理不一样,也没有去研究,下边记录我使用的三种方法 ...

随机推荐

  1. 【转】Parcelable, Serializable,Cloneable,copyProperties

    Copying ... https://blog.csdn.net/max2005/article/details/78325036 存在着三件事,整理如下 Parcelable, Serializa ...

  2. select样式设计

    举例: select { color: blue; /*去掉边框*/ border: none; outline: none; /*去掉箭头*/ -webkit-appearance: none; / ...

  3. 在Github和oschina上搭建自己的博客网站

    在Github上搭建 - 参考链接 搭建一个免费的,无限流量的Blog----github Pages和Jekyll入门 GitHub + Jekyll 搭建并美化个人网站 用Jekyll搭建的Git ...

  4. 同步&异步+阻塞&非阻塞(理解)

    0 - 同步&异步 同步和异步关注的是消息通信机制. 0.1 - 同步 由“调用者”主动等待这个“调用”结果.即是,发出一个“调用”时,在没有得到结果之前,该“调用”不返回,一旦调用返回,则得 ...

  5. 微信小程序入门八头像上传

    1. action-sheet 底部弹出可选菜单组件 2. wx.uploadFile 将本地资源上传到服务器 3. wx.chooseImage 从本地相册选择图片或使用相机拍照. 4. wx.pr ...

  6. SQLServer语法常用总结

    1. 有时候查看SQL的时候表名或者字段名需要加[],这是因为有时候你的表名或者字段名正好与sqlserver的保留字段重了 比如:有一个user表,直接select会报错 select * from ...

  7. CF1096E The Top Scorer

    题目地址:洛谷CF1096E 本场AC数最少 (最难) 的题目 题目大意:给出三个数p , s,r,表示有p人,每个人都有一个非负得分,所有人的得分和为s,Hasan的得分至少为r,求Hasan是第一 ...

  8. 2018 Multi-University Training Contest 1 杭电多校第一场

    抱着可能杭电的多校1比牛客的多校1更恐怖的想法 看到三道签到题 幸福的都快哭出来了好吗 1001  Maximum Multiple(hdoj 6298) 链接:http://acm.hdu.edu. ...

  9. Python3-进程

    进程 什么是进程 进程调度 进程的并行与并发 进程的创建与结束 在python程序中的进程操作 守护进程 进程同步(multiprocess.Lock) 进程间通信——队列 生产者消费者模型 进程池和 ...

  10. ARM的Jazelle技术【转】

    转自:https://blog.csdn.net/ken_yjj/article/details/6797290 Come From: http://www.arm.com/zh/products/p ...