分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 软件开发

js去除空格12种方法

发布时间:2023-09-06 01:18责任编辑:熊小新关键词:js


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


 ?1 //JS去除空格的方法目前共有12种: ?2 //实现1 ?3 ?String.prototype.trim = function() { ?4 ???return this.replace(/^\s\s*/, ‘‘).replace(/\s\s*$/, ‘‘); ?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(/\S\s*$/) + 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*((?:[\S\s]*\S)?)\s*$/, ‘$1‘); 43 ?} 44 //沿着上面两个的思路进行改进,动用了非捕获分组与字符集合,用?顶替了*,效果非常惊人。尤其在IE6中,可 以用疯狂来形容这次性能的提升,直接秒杀火狐。 45 // 实现9 46 ?String.prototype.trim = function() { 47 ???return this.replace(/^\s*([\S\s]*?)\s*$/, ‘$1‘); 48 ?} 49 //这次是用懒惰匹配 顶替非捕获分组,在火狐中得到改善,IE没有上次那么疯狂。 50 ?实现10 51 ?String.prototype.trim = function() { 52 ???var str = this, 53 ???whitespace = ‘ \n\r\t\f\x0b\xa0\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u200b\u2028\u2029\u3000‘; 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(/^\s\s*/, ‘‘), 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(" \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   ?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 第二种:正则替换 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 第四种:使用motools100 [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;    115 }  116 }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 === null126                 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 即为 false136             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)  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 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 233 {  234 keynum = e.keyCode  235 }  236 else if(e.which) // Netscape/Firefox/Opera 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 254 {  255 keynum = e.keyCode  256 }  257 else if(e.which) // Netscape/Firefox/Opera 258 {  259 keynum = e.which  260 }  261 if(keynum == 32){  262 return false;  263 }  264 return true;  265 }  266 267 268 269 270 

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

js去除空格12种方法

原文地址:http://www.cnblogs.com/ios9/p/7680923.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved