正则表达式实际应用

前端之家收集整理的这篇文章主要介绍了正则表达式实际应用前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
一 普通字符匹配
下面是一些在网页编程中经常会遇到的字符匹配模式。
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,sans-serif; font-size: 15px; line-height: 24px;"> 3 用正则表达式限制只能输入数字和英文:
onkeyup="value=value.replace(/[W]/g,sans-serif; font-size: 15px; line-height: 24px;"> 4 用正则表达式限制只能输入全角字符:
onkeyup="value=value.replace(/[^uFF00-uFFFF]/g,clipboardData.getData('text').replace(/[^uFF00-uFFFF]/g,sans-serif; font-size: 15px; line-height: 24px;">
三 去掉重复的字符
利用正则表达式可以去掉字符串中重复的字符。
例如,下面的例子利用正则表达式去掉字符串中重复的字符,然后引用取出包括重复的字符,再以重复的字符建立第二个表达式,取到不重复的字符,两者串连。代码如下:
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。

猜你在找的正则表达式相关文章