1. 程式人生 > >js去除空格12種方法

js去除空格12種方法

num otool temp 它的 兼容性 -s 空格 use string類型


註:本文非本人原著;原文作者: 黃卉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 第四種:使用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;    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 === null
126                 return true;
127             }
128             type = Object.prototype.toString.call(value).slice(8, -1);
129             switch(type) {
130             caseString‘:
131                 return !$.trim(value);
132             caseArray‘:
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     returnfunction‘ == 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種方法