码迷,mamicode.com
首页 > Web开发 > 详细

js正则表达式验证大全--转载

时间:2016-05-18 12:29:26      阅读:309      评论:0      收藏:0      [点我收藏+]

标签:

转载来源:http://www.cnblogs.com/hai-ping/articles/2997538.html#undefined
  1 //判断输入内容是否为空    
  2 function IsNull(){    
  3     var str = document.getElementById(‘str‘).value.trim();    
  4     if(str.length==0){    
  5         alert(‘对不起,文本框不能为空或者为空格!‘);//请将“文本框”改成你需要验证的属性名称!    
  6     }    
  7 }    
  8    
  9 //判断日期类型是否为YYYY-MM-DD格式的类型    
 10 function IsDate(){     
 11     var str = document.getElementById(‘str‘).value.trim();    
 12     if(str.length!=0){    
 13         var reg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/;     
 14         var r = str.match(reg);     
 15         if(r==null)    
 16             alert(‘对不起,您输入的日期格式不正确!‘); //请将“日期”改成你需要验证的属性名称!    
 17         }    
 18 }     
 19    
 20 //判断日期类型是否为YYYY-MM-DD hh:mm:ss格式的类型    
 21 function IsDateTime(){     
 22     var str = document.getElementById(‘str‘).value.trim();    
 23     if(str.length!=0){    
 24         var reg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/;     
 25         var r = str.match(reg);     
 26         if(r==null)    
 27         alert(‘对不起,您输入的日期格式不正确!‘); //请将“日期”改成你需要验证的属性名称!    
 28     }    
 29 }     
 30    
 31 //判断日期类型是否为hh:mm:ss格式的类型    
 32 function IsTime()     
 33 {     
 34     var str = document.getElementById(‘str‘).value.trim();    
 35     if(str.length!=0){    
 36     reg=/^((20|21|22|23|[0-1]\d)\:[0-5][0-9])(\:[0-5][0-9])?$/     
 37         if(!reg.test(str)){    
 38             alert("对不起,您输入的日期格式不正确!");//请将“日期”改成你需要验证的属性名称!    
 39         }    
 40     }    
 41 }     
 42    
 43 //判断输入的字符是否为英文字母    
 44 function IsLetter()     
 45 {     
 46         var str = document.getElementById(‘str‘).value.trim();    
 47         if(str.length!=0){    
 48         reg=/^[a-zA-Z]+$/;     
 49         if(!reg.test(str)){    
 50             alert("对不起,您输入的英文字母类型格式不正确!");//请将“英文字母类型”改成你需要验证的属性名称!    
 51         }    
 52         }    
 53 }     
 54    
 55 //判断输入的字符是否为整数    
 56 function IsInteger()     
 57 {       
 58         var str = document.getElementById(‘str‘).value.trim();    
 59         if(str.length!=0){    
 60         reg=/^[-+]?\d*$/;     
 61         if(!reg.test(str)){    
 62             alert("对不起,您输入的整数类型格式不正确!");//请将“整数类型”要换成你要验证的那个属性名称!    
 63         }    
 64         }    
 65 }     
 66    
 67 //判断输入的字符是否为双精度    
 68 function IsDouble(val)     
 69 {     
 70         var str = document.getElementById(‘str‘).value.trim();    
 71         if(str.length!=0){    
 72         reg=/^[-\+]?\d+(\.\d+)?$/;    
 73         if(!reg.test(str)){    
 74             alert("对不起,您输入的双精度类型格式不正确!");//请将“双精度类型”要换成你要验证的那个属性名称!    
 75         }    
 76         }    
 77 }     
 78    
 79    
 80 //判断输入的字符是否为:a-z,A-Z,0-9    
 81 function IsString()     
 82 {     
 83         var str = document.getElementById(‘str‘).value.trim();    
 84         if(str.length!=0){    
 85         reg=/^[a-zA-Z0-9_]+$/;     
 86         if(!reg.test(str)){    
 87             alert("对不起,您输入的字符串类型格式不正确!");//请将“字符串类型”要换成你要验证的那个属性名称!    
 88         }    
 89         }    
 90 }     
 91    
 92 //判断输入的字符是否为中文    
 93 function IsChinese()     
 94 {     
 95         var str = document.getElementById(‘str‘).value.trim();    
 96         if(str.length!=0){    
 97         reg=/^[\u0391-\uFFE5]+$/;    
 98         if(!reg.test(str)){    
 99             alert("对不起,您输入的字符串类型格式不正确!");//请将“字符串类型”要换成你要验证的那个属性名称!    
100         }    
101         }    
102 }     
103    
104 //判断输入的EMAIL格式是否正确    
105 function IsEmail()     
106 {     
107         var str = document.getElementById(‘str‘).value.trim();    
108         if(str.length!=0){    
109         reg=/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/;    
110         if(!reg.test(str)){    
111             alert("对不起,您输入的字符串类型格式不正确!");//请将“字符串类型”要换成你要验证的那个属性名称!    
112         }    
113         }    
114 }     
115    
116 //判断输入的邮编(只能为六位)是否正确    
117 function IsZIP()     
118 {     
119         var str = document.getElementById(‘str‘).value.trim();    
120         if(str.length!=0){    
121         reg=/^\d{6}$/;    
122         if(!reg.test(str)){    
123             alert("对不起,您输入的字符串类型格式不正确!");//请将“字符串类型”要换成你要验证的那个属性名称!    
124         }    
125         }    
126 }     
127    
128 //判断输入的数字不大于某个特定的数字    
129 function MaxValue()     
130 {     
131     var val = document.getElementById(‘str‘).value.trim();    
132         if(str.length!=0){    
133         reg=/^[-+]?\d*$/;     
134         if(!reg.test(str)){//判断是否为数字类型    
135             if(val>parseInt(‘123‘)) //“123”为自己设定的最大值    
136             {     
137                 alert(‘对不起,您输入的数字超出范围‘);//请将“数字”改成你要验证的那个属性名称!    
138             }     
139         }    
140     }    
141 }     

 1 Phone : /^((\(\d{2,3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$/    
 2  Mobile : /^((\(\d{2,3}\))|(\d{3}\-))?13\d{9}$/    
 3  Url : /^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\‘:+!]*([^<>\"\"])*$/   
 4  IdCard : /^\d{15}(\d{2}[A-Za-z0-9])?$/   
 5  QQ : /^[1-9]\d{4,8}$/   
 6  某种特殊金额:/^((\d{1,3}(,\d{3})*)|(\d+))(\.\d{2})?$/         //说明:除“XXX    XX,XXX    XX,XXX.00”格式外
 7 //为上面提供各个JS验证方法提供.trim()属性   
 8 String.prototype.trim=function(){   
 9   return this.replace(/(^\s*)|(\s*$)/g, "");    
10 }
调用:
 1 <input type="text" name="str" >
 2 <input type="button" value=" 确定 " onClick="">    //onClick中写自己要调用的JS验证函数
 3 <script language="javascript" type="text/javascript">
 4 var patterms = new Object();
 5 //验证IP
 6 patterms.ip = /^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])(\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])){3}$/;
 7 //验证EMAIL
 8 patterms.email = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/;
 9 //验证日期格式2009-07-13
10 patterms.date = /^\d{4}-(0?[1-9]|1[0-2])-(0?[1-9]|[1-2]\d|3[0-1])$/;
11 //验证时间格式16:55:39
12 patterms.time = new RegExp("^([0-1]\\d|2[0-3]):[0-5]\\d:[0-5]\\d$");
13 //验证函数
14 function verify(str,pat){
15     var thePat;
16     thePat = patterms[pat];
17     if(thePat.test(str)){
18         return true;
19     }else{
20         return false;
21     }
22 }
//测试
1 alert(verify("asidycom@163.com","email")+","+verify("192.168.1.1","ip")+
2     ","+verify("16:55:39","time")+","+verify("2009-07-13","date")+","+verify("192.168","ip")); 

 

 1 验证数字:^[0-9]*$ 
 2 验证n位的数字:^\d{n}$  
 3 验证至少n位数字:^\d{n,}$ 
 4 验证m-n位的数字:^\d{m,n}$ 
 5 验证零和非零开头的数字:^(0|[1-9][0-9]*)$ 
 6 验证有两位小数的正实数:^[0-9]+(.[0-9]{2})?$ 
 7 验证有1-3位小数的正实数:^[0-9]+(.[0-9]{1,3})?$ 
 8 验证非零的正整数:^\+?[1-9][0-9]*$ 
 9 验证非零的负整数:^\-[1-9][0-9]*$ 
10 验证非负整数(正整数 + 0) ^\d+$ 
11 验证非正整数(负整数 + 0) ^((-\d+)|(0+))$ 
12 验证长度为3的字符:^.{3}$ 
13 验证由26个英文字母组成的字符串:^[A-Za-z]+$ 
14 验证由26个大写英文字母组成的字符串:^[A-Z]+$ 
15 验证由26个小写英文字母组成的字符串:^[a-z]+$ 
16 验证由数字和26个英文字母组成的字符串:^[A-Za-z0-9]+$ 
17 验证由数字、26个英文字母或者下划线组成的字符串:^\w+$ 
18 验证用户名或昵称经常用到: ^[\u4e00-\u9fa5A-Za-z0-9-_]*$  只能中英文,数字,下划线,减号
19 验证用户密码:^[a-zA-Z]\w{5,17}$ 正确格式为:以字母开头,长度在6-18之间,只能包含字符、数字和下划线。 
20 验证是否含有 ^%&‘,;=?$\" 等字符:[^%&‘,;=?$\x22]+ 
21 验证汉字:^[\u4e00-\u9fa5],{0,}$ 
22 验证Email地址:^\w+[-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$ 
23 验证InternetURL:^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$ ;^[a-zA-z]+://(w+(-w+)*)(.(w+(-w+)*))*(?S*)?$ 
24 验证电话号码:^(\(\d{3,4}\)|\d{3,4}-)?\d{7,8}$:--正确格式为:XXXX-XXXXXXX,XXXX-XXXXXXXX,XXX-XXXXXXX,XXX-XXXXXXXX,XXXXXXX,XXXXXXXX。 
25 验证身份证号(15位或18位数字):^\d{15}|\d{}18$ 
26 验证一年的12个月:^(0?[1-9]|1[0-2])$ 正确格式为:“01”-“09”和“1”“1227 验证一个月的31天:^((0?[1-9])|((1|2)[0-9])|30|31)$ 正确格式为:01、09和1、3128 整数:^-?\d+$ 
29 非负浮点数(正浮点数 + 0):^\d+(\.\d+)?$ 
30 正浮点数 ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$ 
31 非正浮点数(负浮点数 + 0) ^((-\d+(\.\d+)?)|(0+(\.0+)?))$ 
32 负浮点数 ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$ 
33 浮点数 ^(-?\d+)(\.\d+)?$

 

由于手机号段的不断更新,以前的正则表达式已经无法满足需求。重新编写这条表达式,号段资料来源依据:http://www.von-line.com/hao.htm  
1 var regex = {
2     mobile: /^0?(13[0-9]|15[012356789]|18[0236789]|14[57])[0-9]{8}$/
3 }

 

表达式分析:
“/”代表一个正则表达式。
“^”代表字符串的开始位置,“$”代表字符串的结束位置。
“?”代表匹配前面的字符一个或零个,所以这里0?的意思是手机号码可以以0开头或不以0开头。
接下的部分验证11位的手机号码,先从13开始,因为从130-139都有所以可选区间是[0-9],15开头的号码没有154所以[]里面没有4这个数字,当然也可以写成[0-35-9],下面18和14开的号码同上。
小括号括起来的代表一个子表达式,里面是4个可选分支分别用“|”来区分开来,在正则中“|”的优先级是最低的,这里每个分支匹配的都是3个字符(一个[]只能匹配一个字符,里面是可选的意思),也就是手机号码的前3位数字,那么后面还有8位数字需要匹配,可以是0-9的任意字符,所以是“[0-9]{8}”,{}中的数字代表匹配前面字符的个数。分析完毕。





js正则表达式验证大全--转载

标签:

原文地址:http://www.cnblogs.com/xx0405/p/5504464.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!