正则表达式实际应用

一 普通字符匹配
下面是一些在网页编程中经常会遇到的字符匹配模式。
l 匹配中文字符的正则表达式:
[u4e00-u9fa5]
2 匹配双字节字符(包括汉字在内):
[^x00-xff]
3 匹配空行的正则表达式:
n[s|]*r
4 匹配HTML标记的正则表达式:
/<(.*)>.*</1>|<(.*) />/
5 匹配首尾空格的正则表达式:
(^s*)|(s*$)
6 计算字符串的长度(一个双字节字符长度计2,ASCII字符计1):
String.prototype.len=function(){return this.replace([^x00-xff]/g,"aa").length;}
7 匹配网址URL的正则表达式:
http://([w-]+.)+[w-]+(/[w- ./%&=]*)
8 匹配E-mail地址的正则表达式:
w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
 
二 限制表单所输入的内容
在网页编程中,经常会用到限制网页表单中的文本框输入内容的情况,下面是一些利用正则表达式来实现这种功能的例子。
1 用正则表达式限制只能输入中文:
onkeyup="value=value.replace(/[^u4E00-u9FA5]/g,'')"
onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^u4E00-u9FA5]/g,''))"
2 用正则表达式限制只能输入数字:
onkeyup="value=value.replace(/[^d]/g,'') 
"onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]/g,''))"
3 用正则表达式限制只能输入数字和英文:
onkeyup="value=value.replace(/[W]/g,'')
"onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]/g,''))"
4 用正则表达式限制只能输入全角字符:
onkeyup="value=value.replace(/[^uFF00-uFFFF]/g,'')" 
onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^uFF00-uFFFF]/g,''))"
 
三 去掉重复的字符
利用正则表达式可以去掉字符串中重复的字符。
例如,下面的例子利用正则表达式去掉字符串中重复的字符,然后引用取出包括重复的字符,再以重复的字符建立第二个表达式,取到不重复的字符,两者串连。代码如下:
var s="abacabefgeeii"
var s1=s.replace(/(.).*1/g,"$1")
var re=new RegExp("["+s1+"]","g")
var s2=s.replace(re,"")
alert(s1+s2); 
运行结果:abcefgi。

猜你喜欢

转载自cakin24.iteye.com/blog/2354884