js去除空格12种方法
注:本文非本人原著;原文作者: 黄卉 《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 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) 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种方法的更多相关文章
- js去除空格(trim方法)
/** * 去空格 */ String.prototype.trim=function(){ return this.replace(/(^\s*)|(\s*$)/g, ""); ...
- js去除空格,判断是否包含
js去除空格 function trimStr(str){ return str.replace(/(^\s*)|(\s*$)/g,""); } js判断是否包含 //是否包含 f ...
- 判断数组的方法/判断JS数据类型的四种方法
参考文: 以下 3 个判断数组的方法,请分别介绍它们之间的区别和优劣Object.prototype.toString.call() . instanceof 以及 Array.isArray() h ...
- JS去除空格方法记录
JS中去掉空格 //去除空格 String.prototype.Trim = function() { return this.replace(/\s+/g, ""); ...
- js 去掉字符串前后空格5种方法
第一种:循环检查替换 //供使用者调用 function trim(s){ return trimRight(trimLeft(s)); } //去掉左边的空白 function trimLeft(s ...
- JS清除空格之trim()方法
JQ: $.trim() 函数用于去除字符串两端的空白字符. 注意:$.trim()函数会移除字符串开始和末尾处的所有换行符,空格(包括连续的空格)和制表符.如果这些空白字符在字符串中间时,它们将被保 ...
- js 小工具-- 原生 js 去除空格
// 原生js 去除字符串空格 <script type="text/javascript"> String.prototype.trim = function (){ ...
- 动态加载JS脚本的4种方法
实现OPOA(One Page One Application)时,必须使用动态加载js. 也就是在用户选择某个菜单项后,再动态加载对应的全部js到客户端. 动态加载js的情况很多啊,比如解决ajax ...
- OC和JS交互的三种方法
看简书上说一共有六种OC和JS交互的方法,但是前三种原理都一致,都是通过检测.拦截Url地址实现互相调用的.剩下的react native等第三方框架原理不一样,也没有去研究,下边记录我使用的三种方法 ...
随机推荐
- oracle 问题查找 error ora-
Error ORA-03113: 通信通道的文件结尾进程 ID: 2232会话 ID: 1250 序列号: 这是oracle 报的错误, 可能这个03113这个编码的错误有很多. 但是要找到是什么原因 ...
- Linux之Ubuntu下DSL拨号上网
可视化桌面配置方法 1.编辑连接 2.选择 增加 3.选择 DSL 4.选择 新建连接[cmcc@gx属于移动校园用户的ISP指定后缀] 6.OK 当然,还有其他拨号上网的办法: [Linux/Ubu ...
- vscode隐藏运行ts生成的js文件和map文件
在code-首选项-用户设置中放入以下代码,覆盖原有的 { "files.exclude": { "node_modules": true, "**/ ...
- 出题人的手环(牛客练习赛38D 离散化+树状数组)
题目链接(https://ac.nowcoder.com/acm/contest/358/D) 题目描述 出题人的妹子送了出题人一个手环,这个手环上有 n 个珠子,每个珠子上有一个数. 有一天,出题人 ...
- 《从Paxos到Zookeeper:分布式一致性原理与实践》第一章读书笔记
第一章主要介绍了计算机系统从集中式向分布式系统演变过程中面临的挑战,并简要介绍了ACID.CAP和BASE等经典分布式理论,主要包含以下内容: 集中式的特点 分布式的特点 分布式环境的各种问题 ACI ...
- Lr-代理录制
哈哈,第一讲,决定分享一下代理的一些知识,是我学习的总结,可能会有错误,欢迎大家指正. 问题一:代理录制是为了解决什么问题或者说为什么么要使用代理呢? 这是因为lr只能使用IE浏览器进行录制,如果想使 ...
- 帝国cms建站方法和知识点
帝国cms建站方法和知识点 1. 首先在帝国cms网站上下载模板系统.根据模板系统上的提示,将指定的目录文件放在指定的位置.然后进行安装.后台管理系统的命名设置.数据库的设置等等. 2. 安装完成 ...
- spark教程
某大神总结的spark教程, 地址 http://litaotao.github.io/introduction-to-spark?s=inner
- hadoop3.x.x错误解决
错误信息:there is no HDFS_SECONDARYNAMENODE_USER defined. Aborting operation. 解决方案: (缺少用户定义而造成的)因此编辑启动和关 ...
- java jvm和android DVM区别
本文转自:http://blog.csdn.net/yujun411522/article/details/45932247 1.Android dvm的进程和Linux的进程, 应用程序的进 ...