匹配中文字符的正则表达式: [/u4e00-/u9fa5]
匹配双字节字符(包括汉字在内):[^/x00-/xff]
应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
String.prototype.len=function(){return this.replace([^/x00-/xff]/g,"aa").length;}
匹配空行的正则表达式:/n[/s| ]*/r
匹配HTML标记的正则表达式:/<(.*)>.*<///1>|<(.*) //>/
匹配首尾空格的正则表达式:(^/s*)|(/s*$)
应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现,如下:
1: String.prototype.trim = function()
2: {
3: return this.replace(/(^/s*)|(/s*$)/g, "");
4: }
利用正则表达式分解和转换IP地址:
下面是利用正则表达式匹配IP地址,并将IP地址转换成对应数值的Javascript程序:
1: function IP2V(ip)
2: {
3: re=/(/d+)/.(/d+)/.(/d+)/.(/d+)/g //匹配IP地址的正则表达式
4: if(re.test(ip))
5: {
6: return RegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1
7: }
8: else
9: {
10: throw new Error("Not a valid IP address!")
11: }
12: }
不过上面的程序如果不用正则表达式,而直接用split函数来分解可能更简单,程序如下:
1: var ip="10.100.20.168"
2: ip=ip.split(".")
3: alert("IP值是:"+(ip[0]*255*255*255+ip[1]*255*255+ip[2]*255+ip[3]*1))
匹配Email地址的正则表达式:/w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*
匹配网址URL的正则表达式:http://([/w-]+/.)+[/w-]+(/[/w- ./?%&=]*)?
利用正则表达式去除字串中重复的字符的算法程序:[注:此程序不正确,原因见本贴回复]
1: var s="abacabefgeeii"
2: var s1=s.replace(/(.).*/1/g,"$1")
3: var re=new RegExp("["+s1+"]","g")
4: var s2=s.replace(re,"")
5: alert(s1+s2) //结果为:abcefgi
用正则表达式从URL地址中提取文件名的javascript程序,如下结果为page1
1: s="http://www.9499.net/page1.htm"
2: s=s.replace(/(.*//){0,}([^/.]+).*/ig,"$2")
3: alert(s)
利用正则表达式限制网页表单里的文本框输入内容:
用正则表达式限制只能输入中文:用正则表达式限制只能输入全角字符: οnkeyup="value=value.replace(/[^/uFF00-/uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/uFF00-/uFFFF]/g,''))"
用正则表达式限制只能输入数字:οnkeyup="value=value.replace(/[^/d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/d]/g,''))"
用正则表达式限制只能输入数字和英文:οnkeyup="value=value.replace(/[/W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/d]/g,''))"
1: 补充:
2: ^/d+$ //匹配非负整数(正整数 + 0)
3: ^[0-9]*[1-9][0-9]*$ //匹配正整数
4: ^((-/d+)|(0+))$ //匹配非正整数(负整数 + 0)
5: ^-[0-9]*[1-9][0-9]*$ //匹配负整数
6: ^-?/d+$ //匹配整数
7: ^/d+(/./d+)?$ //匹配非负浮点数(正浮点数 + 0)
8: ^(([0-9]+/.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*/.[0-9]+)|([0-9]*[1-9][0-9]*))$ //匹配正浮点数
9: ^((-/d+(/./d+)?)|(0+(/.0+)?))$ //匹配非正浮点数(负浮点数 + 0)
10: ^(-(([0-9]+/.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*/.[0-9]+)|([0-9]*[1-9][0-9]*)))$ //匹配负浮点数
11: ^(-?/d+)(/./d+)?$ //匹配浮点数
12: ^[A-Za-z]+$ //匹配由26个英文字母组成的字符串
13: ^[A-Z]+$ //匹配由26个英文字母的大写组成的字符串
14: ^[a-z]+$ //匹配由26个英文字母的小写组成的字符串
15: ^[A-Za-z0-9]+$ //匹配由数字和26个英文字母组成的字符串
16: ^/w+$ //匹配由数字、26个英文字母或者下划线组成的字符串
17: ^[/w-]+(/.[/w-]+)*@[/w-]+(/.[/w-]+)+$ //匹配email地址
18: ^[a-zA-z]+://匹配(/w+(-/w+)*)(/.(/w+(-/w+)*))*(/?/S*)?$ //匹配url
19:
另外一些:
1: //整数
2: "int":"^([+-]?)//d+$",
3: //正整数
4: "int+":"^([+]?)//d+$",
5: //负整数
6: "int-":"^-//d+$",
7: //数字
8: "num":"^([+-]?)//d*//.?//d+$",
9: //正数
10: "num+":"^([+]?)//d*//.?//d+$"
11: //负数
12: "num-":"^-//d*//.?//d+$",
13: //浮点数
14: "float":"^([+-]?)//d*//.//d+$",
15: //正浮点数
16: "float+":"^([+]?)//d*//.//d+$",
17: //负浮点数
18: "float-":"^-//d*//.//d+$",
19: //邮件
20: "email":"^//w+((-//w+)|(//.//w+))*//@[A-Za-z0-9]+((//.|-)[A-Za-z0-9]+)*//.[A-Za-z0-9]+$",
21: //颜色
22: "color":"^#[a-fA-F0-9]{6}"
23: //联接
24: "url":"^http[s]?://([//w-]+//.)+[//w-]+([//w-./?%&=]*)?$",
25: //仅中文
26: "chinese":"^[//u4E00-//u9FA5//uF900-//uFA2D]+$"
27: //仅ACSII字符
28: "ascii":"^[//x00-//xFF]+$"
29: //邮编
30: "zipcode":"^//d{6}$"
31: //手机
32: "mobile":"^0{0,1}13[0-9]{9}$"
33: //ip地址
34: "ip4":"^/(([0-1]//d{0,2})|(2[0-5]{0,2}))//.(([0-1]//d{0,2})|(2[0-5]{0,2}))//.(([0-1]//d{0,2})|(2[0-5]{0,2}))//.(([0-1]//d{0,2})|(2[0-5]{0,2}))$",
35: //非空
36: "notempty":"^//S+$"
37: //图片
38: "picture":"(.*)//.(jpg|bmp|gif|ico|pcx|jpeg|tif|png|raw|tga)$"
39: //压缩文件
40: "rar":"(.*)//.(rar|zip|7zip|tgz)$"
41: //日期
42: "date":"^//d{2,4}[/-]?((((0?[13578])|(1[02]))[///|//-]?((0?[1-9]|[0-2][0-9])|(3[01])))|(((0?[469])|(11))[///|//-]?((0?[1-9]|[0-2][0-9])|(30)))|(0?[2][/-]?(0?[1-9]|[0-2][0-9])))$",
43: //时间
44: "time":"^(20|21|22|23|[01]//d|//d)(([:.][0-5]//d){1,2})$"