配色: 字号:
javascript中使用正则表达式实现删除字符串中的前后空格
2016-09-05 | 阅:  转:  |  分享 
  
javascript中使用正则表达式实现删除字符串中的前后空格

在前台应用进我们经常会碰到要删除用户输入的字符中的空格的问题,下面我们来介绍一下javascript中使用正则表达式实现删除字符串中的空格方法

实例

复制代码代码如下:



实例模仿RTrim:

复制代码代码如下:



实例代码以及测试代码如下:

复制代码代码如下:

//删除字符串两侧的空白字符。functiontrim(str){returnstr.replace(/^s+|s+$/g,'''');}//删除字符串左侧的空白字符。functionltrim(str){returnstr.replace(/^s+/g,'''');}//删除字符串右侧的空白字符。functionrtrim(str){returnstr.replace(/s+$/g,'''');}//以下为测试代码vartrimTest="123456789";//前后各有一个空格。document.write(''length:''+trimTest.length+''
'');//使用前document.write(''ltrimlength:''+ltrim(trimTest).length+''
'');//使用ltrim后document.write(''rtrimlength:''+rtrim(trimTest).length+''
'');//使用rtrim后document.write(''trimlength:''+trim(trimTest).length+''
'');//使用trim后

测试的结果如下:

复制代码代码如下:

length:11ltrimlength:10rtrimlength:10trimlength:9

用js正则表达式删除字符串前后空格

复制代码代码如下:

String.prototype.trim=function(){varreSpace=/^\s(.?)\s$/;returnthis.replace(www.hunanwang.net);};

让我们分析一下第二行的正则表达式^行开始\s匹配字符前面的所有空格,贪婪模式重复(.?)捕获组,勉强模式重复匹配任意字符,也就是我们最终需要(去掉前后空格后)的字符,这个不是很好理解(我认为)第一:我原来认为在捕获组内也应该判断第一个字符应该不能为空格即写成([^\s+])的形式,但这是完全没有必要的因为捕获组前面的\s已经能捕获开头的所有的空格字符了,你认为的捕获组的字符开始范围与正则表达式匹配的字符范围是不一样的,汗~有点说不清楚了,呵呵第二:其中?的作用,他的作用就是勉强模式重复前面的字符,什么意思呢?就是如果我用(.a)去匹配aaaaaaa字符串的结果就是(aaaaaaa)源字符串这叫贪婪模式,如果用(.?a)去匹配aaaaaaa的话他就会先匹配第一a,然后是第二个a,然后是第三个a…….这就叫勉强模式匹配有的地方也叫懒惰模式匹配。通俗一点(大家都喜欢通俗的解释,呵呵)就是前者是从后往前去匹配尽可能多的字符,而后者是从前往后匹配第三:我们还要不要去关心捕获组中后面的空格呢?因为捕获组中的”.”也是可以匹配空格的,先前我也是考虑这个问题大部分时间都浪费在这上面了.其实这和考虑要不要排除捕获组前面的空格一样的道理,后面的\s已经给我们处理了\s匹配字符后面的空格———————————————————分割线——————————————————–自定义三个trim()函数来过滤字符串左右两边的空格。

复制代码代码如下:

//js去除空格函数//此处为string类添加三个成员String.prototype.Trim=function(){returnTrim(this);}String.prototype.LTrim=function(){returnLTrim(this);}String.prototype.RTrim=function(){returnRTrim(this);}//此处为独立函数functionLTrim(str){vari;for(i=0;i=0;i–){if(str.charAt(i)!=”“&&str.charAt(i)!=”“)break;}str=str.substring(0,i+1);returnstr;}functionTrim(str){returnLTrim(RTrim(str));}

———————————————————分割线——————————————————–

复制代码代码如下:

functiontrim(str){//删除左右两端的空格returnstr.replace(/(^\s)|(\s$)/g,“”);}functionltrim(str){//删除左边的空格returnstr.replace(/(^\s)/g,”");}functionrtrim(str){//删除右边的空格returnstr.replace(/(\s$)/g,”");}functioncheckSubmit(){if(confirm(“是否确认保存数据?”)){varab=document.getElementById(“name”).value;vardj=document.getElementById(“dj”).value;varxy=ab.replace(/(^\s)|(\s$)/g,“”);if(xy!=”"&&dj!=”"){document.dwbzjlspb.action=“”;document.dwbzjlspb.submit();returntrue;}else{alert(“单位名称或拟申报等级不能为空!”);}}else{returnfalse;}};



献花(0)
+1
(本文系白狐一梦首藏)