匹配中文字符的正则表达式: [\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)
利用正则表达式限制网页表单里的文本框输入内容: 用正则表达式限制只能输入中文:用正则表达式限制只能输入全角字符: onkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))" 用正则表达式限制只能输入数字:onkeyup="value=value.replace(/[^\d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))" 用正则表达式限制只能输入数字和英文:onkeyup="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})$"
(责任编辑:admin) |