最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
JS表单验证方法实例小结【电话、身份证号、Email、中文、特殊字符、身份证号等】
时间:2017-04-05 编辑:简简单单 来源:一聚教程网
回回写表单,回回要写不同的检查JS,很麻烦,后来写了通用的检查函数,很粗糙,但比较实用,以后再好好改改:
包含页: Check-Form.js
代码如下:
代码如下 | 复制代码 |
//规则检查排序 functionRegCheck(objs) { varstr = objs.checktype; switch(str) { case"cn": //要检查的表单控件的输入类型必须为中文 returnCnWordRegCheck(objs); break; case"idnum": returnIdCardRegCheck(objs);//要检查的表单控件的输入类型必须为身份证号 break; case"num": //要检查的表单控件的输入类型必须为数字 returnNumRegCheck(objs); break; case"mail": //要检查的表单控件的输入类型必须为EMAIL returnEmailRegCheck(objs); break; case"txt": //要检查的表单控件的输入类型必须为字符串 returnSpecialWordRegCheck(objs); break; case"notes": returntrue;//要检查的表单控件的输入类型必须为什么都可以 break; } } //************************************************ //检查电话号码 functionNumRegCheck(obj) { varuplimit = obj.checkrule.split(",")[0]; vardownlimit = obj.checkrule.split(",")[1]; varreg =""; if(downlimit ==null) { reg = eval_r("/^[0-9]{"+uplimit+"}$/"); } else { reg = eval_r("/^[0-9]{"+uplimit+","+downlimit+"}$/"); } varstr = obj.value; varflag = reg.test(str); returnflag; } //************************************************ //检查身份证号 functionIdCardRegCheck(obj) { varstr = obj.value; varreg = /^([0-9]{15}|[0-9]{18})$/; varflag = reg.test(str); returnflag; } //************************************************ //检查EMAIL functionEmailRegCheck(obj) { varstr = obj.value; varreg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((\.[a-zA-Z0-9_-]{2,3}){1,2})$/; varflag = reg.test(str); returnflag; } //*************************************** //检查中文输入 functionCnWordRegCheck(obj) { varstr = obj.value; varreg=/^[\u4e00-\u9fa5](\s*[\u4e00-\u9fa5])*$/; varflag = reg.test(str); //alert(flag); returnflag; } //*************************************** //检查特殊字符 functionSpecialWordRegCheck(obj) { varreg= /[(\/)(<)(>)]/g">\\)(')(")(<)(>)]/g; varstr = obj.value; varflag= reg.test(str); flag = !flag; returnflag; } //************************************************ //检查主引导函数 functionCheckForm(obj) { varmyform = eval_r("document."+obj.name); for(i=0;i { varformvalue = myform.elements[i].value; //内容非空检查,长度检查 if((myform.elements[i].value =="")||(myform.elements[i].value.length>myform.elements[i].maxlength)) { alert("您忘了填写"+myform.elements[i].cnname+"!"+"或者您填写的信息不符合规范!"); myform.elements[i].focus(); returnfalse; break; } if(myform.elements[i].value == 0) { alert("您忘了选择"+myform.elements[i].cnname+"!"); myform.elements[i].focus(); returnfalse; break; } //数据规范化检查 varmyobj = myform.elements[i]; //alert(myobj.checktype); //break; if(!RegCheck(myobj)) { alert(myobj.cnname+"输入有误,请按填写要求填写!"); myobj.focus(); returnfalse; break; } } } |
附:js身份证号码严格验证
代码如下 | 复制代码 |
functioncheckIdcard(idcard){ varErrors=newArray( "验证通过!", "身份证号码位数不对!", "身份证号码出生日期超出范围或含有非法字符!", "身份证号码校验错误!", "身份证地区非法!" ); vararea={11:"北京",12:"天津",13:"河北",14:"山西",15:"内蒙古",21:"辽宁",22:"吉林",23:"黑龙江",31:"上海",32:"江苏",33:"浙江",34:"安徽",35:"福建",36:"江西",37:"山东",41:"河南",42:"湖北",43:"湖南",44:"广东",45:"广西",46:"海南",50:"重庆",51:"四川",52:"贵州",53:"云南",54:"西藏",61:"陕西",62:"甘肃",63:"青海",64:"宁夏",65:"新疆",71:"台湾",81:"香港",82:"澳门",91:"国外"} varidcard,Y,JYM; varS,M; varidcard_array =newArray(); idcard_array = idcard.split(""); //地区检验 if(area[parseInt(idcard.substr(0,2))]==null)returnErrors[4]; //身份号码位数及格式检验 switch(idcard.length){ case15: if( (parseInt(idcard.substr(6,2))+1900) % 4 == 0 || ((parseInt(idcard.substr(6,2))+1900) % 100 == 0 && (parseInt(idcard.substr(6,2))+1900) % 4 == 0 )){ ereg=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}$/;//测试出生日期的合法性 }else{ ereg=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}$/;//测试出生日期的合法性 } if(ereg.test(idcard))returnErrors[0]; elsereturnErrors[2]; break; case18: //18位身份号码检测 //出生日期的合法性检查 //闰年月日:((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9])) //平年月日:((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8])) if( parseInt(idcard.substr(6,4)) % 4 == 0 || (parseInt(idcard.substr(6,4)) % 100 == 0 && parseInt(idcard.substr(6,4))%4 == 0 )){ ereg=/^[1-9][0-9]{5}19[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}[0-9Xx]$/;//闰年出生日期的合法性正则表达式 }else{ ereg=/^[1-9][0-9]{5}19[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}[0-9Xx]$/;//平年出生日期的合法性正则表达式 } if(ereg.test(idcard)){//测试出生日期的合法性 //计算校验位 S = (parseInt(idcard_array[0]) + parseInt(idcard_array[10])) * 7 + (parseInt(idcard_array[1]) + parseInt(idcard_array[11])) * 9 + (parseInt(idcard_array[2]) + parseInt(idcard_array[12])) * 10 + (parseInt(idcard_array[3]) + parseInt(idcard_array[13])) * 5 + (parseInt(idcard_array[4]) + parseInt(idcard_array[14])) * 8 + (parseInt(idcard_array[5]) + parseInt(idcard_array[15])) * 4 + (parseInt(idcard_array[6]) + parseInt(idcard_array[16])) * 2 + parseInt(idcard_array[7]) * 1 + parseInt(idcard_array[8]) * 6 + parseInt(idcard_array[9]) * 3 ; Y = S % 11; M ="F"; JYM ="10X98765432"; M = JYM.substr(Y,1);//判断校验位 if(M == idcard_array[17])returnErrors[0];//检测ID的校验位 elsereturnErrors[3]; } elsereturnErrors[2]; break; default: returnErrors[1]; break; } } alert(checkIdcard("220183198808081610")) |
-
上一个: canvas实现十二星座星空图
-
下一个: JS去除字符串中空格的方法
相关文章
- HTML简单购物数量小程序代码展示 10-31
- html canvas实现弹幕功能 10-31
- HTML中空格表示的意义 10-31
- html area标签解读 10-31
- html使用表单标签实现注册页面代码展示 10-31
- 使用HTML截图并保存为本地图片的代码展示 10-31