技术头条 - 一个快速在微博传播文章的方式     搜索本站
您现在的位置首页 --> JavaScript --> javascript 验证例子,让你精通js

javascript 验证例子,让你精通js

浏览:1620次  出处信息

题目和答案,让你更加了解JS
要求:一、移动电话号码为11或12位,如果为12位,那么第一位为0
二、11位移动电话号码的第一位和第二位为”13″
三、12位移动电话号码的第二位和第三位为”13″
用途:检查输入手机号码是否正确
输入:
s:字符串
返回:
如果通过验证返回true,否则返回false
*/
代码

   1. function f_check_mobile(obj){    
   2.     var regu =/(^[1][3][0-9]{9}$)|(^0[1][3][0-9]{9}$)/;  
   3.     var re = new RegExp(regu);  
   4.     if (re.test( obj.value )) {  
   5.       return true;  
   6.     }  
   7.     f_alert(obj,”请输入正确的手机号码”);  
   8.     return false;    
   9. }  
  10.    

/*
要求:一、电话号码由数字、”(”、”)”和”-”构成
二、电话号码为3到8位
三、如果电话号码中包含有区号,那么区号为三位或四位
四、区号用”(”、”)”或”-”和其他部分隔开
用途:检查输入的电话号码格式是否正确
输入:
strPhone:字符串
返回:
如果通过验证返回true,否则返回false
*/
代码

   1. function f_check_phone(obj)  
   2. {  
   3.     var regu =/(^([0][1-9]{2,3}[-])?\d{3,8}(-\d{1,6})?$)|(^\([0][1-9]{2,3}\)\d{3,8}(\(\d{1,6}\))?$)|(^\d{3,8}$)/;  
   4.     var re = new RegExp(regu);  
   5.     if (re.test( obj.value )) {  
   6.       return true;  
   7.     }  
   8.     f_alert(obj,”请输入正确的电话号码”);  
   9.     return false;  
  10. }  
  11.    

/* 判断是否为邮政编码 */
代码

   1. function f_check_zipcode(obj)  
   2. {  
   3.     if(!f_check_number(obj))  
   4.         return false;  
   5.     if(obj.value.length!=6)  
   6.     {  
   7.         f_alert(obj,”邮政编码长度必须是6位”);  
   8.         return false;  
   9.     }  
  10.     return true;  
  11. }  
  12.    

/*
用户ID,可以为数字、字母、下划线的组合,
第一个字符不能为数字,且总长度不能超过20。
*/
代码

   1. function f_check_userID(obj)  
   2. {  
   3.     var userID = obj.value;  
   4.     if(userID.length > 20)  
   5.     {  
   6.         f_alert(obj,”ID长度不能大于20″);  
   7.         return false;  
   8.     }  
   9.  
  10.     if(!isNaN(userID.charAt(0)))  
  11.     {  
  12.         f_alert(obj,”ID第一个字符不能为数字”);  
  13.         return false;  
  14.     }  
  15.     if(!/^\w{1,20}$/.test(userID))  
  16.     {  
  17.         f_alert(obj,”ID只能由数字、字母、下划线组合而成”);  
  18.         return false;  
  19.     }  
  20.     return true;  
  21. }  
  22.    

/*
功能:验证身份证号码是否有效
提示信息:未输入或输入身份证号不正确!
使用:f_check_IDno(obj)
返回:bool
*/
代码

   1. function f_check_IDno(obj)  
   2. {  
   3.     var aCity={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:”国外”};  
   4.    
   5.     var iSum = 0;  
   6.     var info = “”;  
   7.     var strIDno = obj.value;  
   8.     var idCardLength = strIDno.length;    
   9.     if(!/^\d{17}(\d|x)$/i.test(strIDno)&&!/^\d{15}$/i.test(strIDno))  
  10.     {  
  11.         f_alert(obj,”非法身份证号”);  
  12.         return false;  
  13.     }  
  14.    
  15.     //在后面的运算中x相当于数字10,所以转换成a  
  16.     strIDno = strIDno.replace(/x$/i,”a”);  
  17.  
  18.     if(aCity[parseInt(strIDno.substr(0,2))]==null)  
  19.     {  
  20.         f_alert(obj,”非法地区”);  
  21.         return false;  
  22.     }  
  23.      
  24.     if (idCardLength==18)  
  25.     {  
  26.         sBirthday=strIDno.substr(6,4)+”-”+Number(strIDno.substr(10,2))+”-”+Number(strIDno.substr(12,2));  
  27.         var d = new Date(sBirthday.replace(/-/g,”/”))  
  28.         if(sBirthday!=(d.getFullYear()+”-”+ (d.getMonth()+1) + “-” + d.getDate()))  
  29.         {        
  30.             f_alert(obj,”非法生日”);  
  31.             return false;  
  32.         }  
  33.  
  34.         for(var i = 17;i>=0;i -)  
  35.             iSum += (Math.pow(2,i) % 11) * parseInt(strIDno.charAt(17 - i),11);  
  36.  
  37.         if(iSum%11!=1)  
  38.         {  
  39.             f_alert(obj,”非法身份证号”);  
  40.             return false;  
  41.         }  
  42.     }  
  43.     else if (idCardLength==15)  
  44.     {  
  45.         sBirthday = “19″ + strIDno.substr(6,2) + “-” + Number(strIDno.substr(8,2)) + “-” + Number(strIDno.substr(10,2));  
  46.         var d = new Date(sBirthday.replace(/-/g,”/”))  
  47.         var dd = d.getFullYear().toString() + “-” + (d.getMonth()+1) + “-” + d.getDate();    
  48.         if(sBirthday != dd)  
  49.         {  
  50.             f_alert(obj,”非法生日”);  
  51.             return false;  
  52.         }  
  53.     }  
  54.     return true;  
  55. }  
  56.    

/*
* 判断字符串是否符合指定的正则表达式
*/
代码

   1. function f_check_formatStr(obj)  
   2. {  
   3.     var str = obj.value;  
   4.     var dtype = obj.eos_datatype;  
   5.     var regu = dtype.substring(dtype.indexOf(”(”)+1,dtype.indexOf(”)”));    //指定的正则表达式  
   6.     var re = new RegExp(regu);  
   7.     if(re.test(str))  
   8.         return true;  
   9.     f_alert(obj , “不符合指定的正则表达式要求”);  
  10.     return false;    
  11. }  
  12.    

/*
功能:判断是否为日期(格式:yyyy年MM月dd日,yyyy-MM-dd,yyyy/MM/dd,yyyyMMdd)
提示信息:未输入或输入的日期格式错误!
使用:f_check_date(obj)
返回:bool
*/
代码

   1. function f_check_date(obj)  
   2. {  
   3.     var date = Trim(obj.value);  
   4.     var dtype = obj.eos_datatype;  
   5.     var format = dtype.substring(dtype.indexOf(”(”)+1,dtype.indexOf(”)”));  //日期格式  
   6.     var year,month,day,datePat,matchArray;  
   7.  
   8.     if(/^(y{4})(-|\/)(M{1,2})\2(d{1,2})$/.test(format))  
   9.         datePat = /^(\d{4})(-|\/)(\d{1,2})\2(\d{1,2})$/;  
  10.     else if(/^(y{4})(年)(M{1,2})(月)(d{1,2})(日)$/.test(format))  
  11.         datePat = /^(\d{4})年(\d{1,2})月(\d{1,2})日$/;  
  12.     else if(format==”yyyyMMdd”)  
  13.         datePat = /^(\d{4})(\d{2})(\d{2})$/;  
  14.     else  
  15.     {  
  16.         f_alert(obj,”日期格式不对”);  
  17.         return false;  
  18.     }  
  19.     matchArray = date.match(datePat);  
  20.     if(matchArray == null)  
  21.     {  
  22.         f_alert(obj,”日期长度不对,或日期中有非数字符号”);  
  23.         return false;  
  24.     }  
  25.     if(/^(y{4})(-|\/)(M{1,2})\2(d{1,2})$/.test(format))  
  26.     {  
  27.         year = matchArray[1];  
  28.         month = matchArray[3];  
  29.         day = matchArray[4];  
  30.     } else  
  31.     {  
  32.         year = matchArray[1];  
  33.         month = matchArray[2];  
  34.         day = matchArray[3];  
  35.     }  
  36.     if (month < 1 || month > 12)  
  37.     {              
  38.         f_alert(obj,”月份应该为1到12的整数”);  
  39.         return false;  
  40.     }  
  41.     if (day < 1 || day > 31)  
  42.     {  
  43.         f_alert(obj,”每个月的天数应该为1到31的整数”);  
  44.         return false;  
  45.     }      
  46.     if ((month==4 || month==6 || month==9 || month==11) && day==31)  
  47.     {  
  48.         f_alert(obj,”该月不存在31号”);  
  49.         return false;  
  50.     }      
  51.     if (month==2)  
  52.     {  
  53.         var isleap=(year % 4==0 && (year % 100 !=0 || year % 400==0));  
  54.         if (day>29)  
  55.         {                
  56.             f_alert(obj,”2月最多有29天”);  
  57.             return false;  
  58.         }  
  59.         if ((day==29) && (!isleap))  
  60.         {                
  61.             f_alert(obj,”闰年2月才有29天”);  
  62.             return false;  
  63.         }  
  64.     }  
  65.     return true;  
  66. }  
  67.    

/*
功能:校验的格式为yyyy年MM月dd日HH时mm分ss秒,yyyy-MM-dd HH:mm:ss,yyyy/MM/dd HH:mm:ss,yyyyMMddHHmmss
提示信息:未输入或输入的时间格式错误
使用:f_check_time(obj)
返回:bool
*/
代码

   1. function f_check_time(obj)  
   2. {  
   3.     var time = Trim(obj.value);  
   4.     var dtype = obj.eos_datatype;  
   5.     var format = dtype.substring(dtype.indexOf(”(”)+1,dtype.indexOf(”)”));  //日期格式  
   6.     var datePat,matchArray,year,month,day,hour,minute,second;  
   7.  
   8.     if(/^(y{4})(-|\/)(M{1,2})\2(d{1,2}) (HH:mm:ss)$/.test(format))  
   9.         datePat = /^(\d{4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/;  
  10.     else if(/^(y{4})(年)(M{1,2})(月)(d{1,2})(日)(HH时mm分ss秒)$/.test(format))  
  11.         datePat = /^(\d{4})年(\d{1,2})月(\d{1,2})日(\d{1,2})时(\d{1,2})分(\d{1,2})秒$/;  
  12.     else if(format == “yyyyMMddHHmmss”)  
  13.         datePat = /^(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})$/;  
  14.     else  
  15.     {  
  16.         f_alert(obj,”日期格式不对”);  
  17.         return false;  
  18.     }  
  19.     matchArray = time.match(datePat);  
  20.     if(matchArray == null)  
  21.     {  
  22.         f_alert(obj,”日期长度不对,或日期中有非数字符号”);  
  23.         return false;  
  24.     }  
  25.     if(/^(y{4})(-|\/)(M{1,2})\2(d{1,2}) (HH:mm:ss)$/.test(format))  
  26.     {  
  27.         year = matchArray[1];  
  28.         month = matchArray[3];  
  29.         day = matchArray[4];  
  30.         hour = matchArray[5];  
  31.         minute = matchArray[6];  
  32.         second = matchArray[7];  
  33.     } else  
  34.     {  
  35.         year = matchArray[1];  
  36.         month = matchArray[2];  
  37.         day = matchArray[3];  
  38.         hour = matchArray[4];  
  39.         minute = matchArray[5];  
  40.         second = matchArray[6];  
  41.     }  
  42.     if (month < 1 || month > 12)  
  43.     {              
  44.         f_alert(obj,”月份应该为1到12的整数”);  
  45.         return false;  
  46.     }  
  47.     if (day < 1 || day > 31)  
  48.     {            
  49.         f_alert(obj,”每个月的天数应该为1到31的整数”);  
  50.         return false;  
  51.     }      
  52.     if ((month==4 || month==6 || month==9 || month==11) && day==31)  
  53.     {          
  54.         f_alert(obj,”该月不存在31号”);  
  55.         return false;  
  56.     }      
  57.     if (month==2)  
  58.     {  
  59.         var isleap=(year % 4==0 && (year % 100 !=0 || year % 400==0));  
  60.         if (day>29)  
  61.         {                
  62.             f_alert(obj,”2月最多有29天”);  
  63.             return false;  
  64.         }  
  65.         if ((day==29) && (!isleap))  
  66.         {                
  67.             f_alert(obj,”闰年2月才有29天”);  
  68.             return false;  
  69.         }  
  70.     }  
  71.     if(hour<0 || hour>23)  
  72.     {  
  73.         f_alert(obj,”小时应该是0到23的整数”);  
  74.         return false;  
  75.     }  
  76.     if(minute<0 || minute>59)  
  77.     {  
  78.         f_alert(obj,”分应该是0到59的整数”);  
  79.         return false;  
  80.     }  
  81.     if(second<0 || second>59)  
  82.     {  
  83.         f_alert(obj,”秒应该是0到59的整数”);  
  84.         return false;  
  85.     }  
  86.     return true;  
  87. }  
  88.    

/*判断当前对象是否可见*/
代码

   1. function isVisible(obj){  
   2.     var visAtt,disAtt;  
   3.     try{  
   4.         disAtt=obj.style.display;  
   5.         visAtt=obj.style.visibility;  
   6.     }catch(e){}  
   7.     if(disAtt==”none” || visAtt==”hidden”)  
   8.         return false;  
   9.     return true;  
  10. }  
  11.    

/*判断当前对象及其父对象是否可见*/
代码

   1. function checkPrVis(obj){  
   2.     var pr=obj.parentNode;  
   3.     do{  
   4.         if(pr == undefined || pr == “undefined”) return true;  
   5.         else{  
   6.             if(!isVisible(pr)) return false;  
   7.         }  
   8.     }while(pr=pr.parentNode);  
   9.     return true;  
  10. }  
  11.    

/* 弹出警告对话框,用户点确定后将光标置于出错文本框上, 并且将原来输入内容选中。*/
代码

   1. function f_alert(obj,alertInfo)  
   2. {  
   3.     var caption = obj.getAttribute(”eos_displayname”);  
   4.     if(caption == null)  
   5.         caption = “”;  
   6.     alert(caption + “:” + alertInfo + “!”);  
   7.     obj.select();  
   8.     if(isVisible(obj) && checkPrVis(obj))  
   9.         obj.focus();  
  10. }  
  11.    

/**
* 检测字符串是否为空
*/
代码

   1. function isnull(str)  
   2. {  
   3.     var i;  
   4.     if(str.length == 0)  
   5.         return true;  
   6.     for (i=0;i<str.length;i++)  
   7.     {  
   8.         if (str.charAt(i)!=’ ‘)  
   9.             return false;  
  10.     }  
  11.     return true;  
  12. }  
  13.    

/**
* 检测指定文本框输入是否合法。
* 如果用户输入的内容有错,则弹出提示对话框,
* 同时将焦点置于该文本框上,并且该文本框前面
* 会出现一个警告图标(输入正确后会自动去掉)。
*/
代码

   1. function checkInput(object)  
   2. {  
   3.     var image;  
   4.     var i;  
   5.     var length;  
   6.  
   7.     if(object.eos_maxsize + “” != “undefined”) length = object.eos_maxsize;  
   8.     else length = 0;  
   9.  
  10.     if (object.eos_isnull==”true” && isnull(object.value))  return true;  
  11.  
  12.     /* 长度校验 */  
  13.     if(length != 0 && strlen(object.value) > parseInt(length)) {  
  14.             f_alert(object, “超出最大长度” + length);  
  15.             return false;  
  16.     }  
  17.     /* 数据类型校验 */  
  18.     else {  
  19.         if (object.eos_datatype + “” != “undefined”)  
  20.         {        
  21.  
  22.             var dtype = object.eos_datatype;  
  23.             var objName = object.name;  
  24.             //如果类型名后面带有括号,则视括号前面的字符串为校验类型  
  25.             if(dtype.indexOf(”(”) != -1)  
  26.                 dtype = dtype.substring(0,dtype.indexOf(”(”));  
  27.             //根据页面元素的校验类型进行校验  
  28.             try{  
  29.                 if(eval(”f_check_” + dtype + “(object)”) != true)  
  30.                     return false;  
  31.             }catch(e){return true;}  
  32.             /*  如果form中存在name前半部分相同,并且同时存在以”min”和”max”结尾的表单域,
  33.                 那么视为按区间查询。即”min”结尾的表单域的值要小于等于”max”结尾的表单域的值。 */  
  34.             if(objName.substring((objName.length-3),objName.length)==”min”)  
  35.             {  
  36.                 var objMaxName = objName.substring(0, (objName.length-3)) + “max”;  
  37.                 if(document.getElementById(objMaxName) != undefined && document.getElementById(objMaxName) != “undefined” )  
  38.                 {  
  39.                     if(checkIntervalObjs(object, document.getElementById(objMaxName)) != true)  
  40.                         return false;                    
  41.                 }  
  42.             }            
  43.         }  
  44.     }  
  45.     return true;  
  46. }  
  47.    

/* 检测表单中所有输入项的正确性,一般用于表单的onsubmit事件 */
代码

   1. function checkForm(myform)  
   2. {  
   3.     var i;  
   4.     for (i=0;i<myform.elements.length;i++)  
   5.     {  
   6.         /* 非自定义属性的元素不予理睬 */      
   7.         if (myform.elements[i].eos_displayname + “” == “undefined”) continue;  
   8.         /* 非空校验 */  
   9.         if (myform.elements[i].eos_isnull==”false” && isnull(myform.elements[i].value)){  
  10.             f_alert(myform.elements[i],”不能为空”);  
  11.             return false;  
  12.         }        
  13.         /* 数据类型校验 */  
  14.         if (checkInput(myform.elements[i])==false)  
  15.             return false;                
  16.     }  
  17.     return true;  
  18. }  
  19.    

/**
* 校验两个表单域数据的大小,目前只允许比较日期和数字。
* @param obj1 小值表单域
* @param obj2 大值表单域
*/
代码

   1. function checkIntervalObjs(obj1 , obj2)  
   2. {    
   3.     var caption1 = obj1.getAttribute(”eos_displayname”);  
   4.     var caption2 = obj2.getAttribute(”eos_displayname”);  
   5.     var val1 = parseFloat(obj1.value);  
   6.     var val2 = parseFloat(obj2.value);  
   7.     // 非自定义属性的元素不予理睬  
   8.     if (obj1.eos_displayname + “” == “undefined” || obj2.eos_displayname + “” == “undefined”) {  
   9.         return false;  
  10.     }  
  11.     // 日期类型的比较  
  12.     if(f_check_date(obj1) == true && f_check_date(obj2) == true){  
  13.         var dtype = obj1.eos_datatype;  
  14.         var format = dtype.substring(dtype.indexOf(”(”)+1,dtype.indexOf(”)”));  //日期格式  
  15.         val1 = getDateByFormat(obj1.value, format);  
  16.         dtype = obj2.eos_datatype;  
  17.         format = dtype.substring(dtype.indexOf(”(”)+1,dtype.indexOf(”)”));  //日期格式  
  18.         val2 = getDateByFormat(obj2.value, format);  
  19.         if(val1 > val2){  
  20.         obj2.select();  
  21.         if(isVisible(obj) && checkPrVis(obj))  
  22.             obj2.focus();  
  23.         alert(caption1 + “的起始日期不能大于其终止日期!”);  
  24.         return false;  
  25.         }  
  26.     }  
  27.     // 数字类型的比较  
  28.     if((isNaN(val1) && !isnull(val1)) || (isNaN(val2) && !isnull(val2))){  
  29.         alert(caption1 + “的值不全为数字则不能比较!”);  
  30.         return false;  
  31.     }  
  32.     if(val1 > val2){  
  33.         obj2.select();  
  34.         if(isVisible(obj) && checkPrVis(obj))  
  35.             obj2.focus();  
  36.         alert(caption1 + “的起始值不能大于其终止值!”);  
  37.         return false;  
  38.     }  
  39.     return true;  
  40. }  
  41.    

/*根据日期格式,将字符串转换成Date对象。
格式:yyyy-年,MM-月,dd-日,HH-时,mm-分,ss-秒。
(格式必须写全,例如:yy-M-d,是不允许的,否则返回null;格式与实际数据不符也返回null。)
默认格式:yyyy-MM-dd HH:mm:ss,yyyy-MM-dd。*/
代码

   1. function getDateByFormat(str){  
   2.     var dateReg,format;  
   3.     var y,M,d,H,m,s,yi,Mi,di,Hi,mi,si;  
   4.     if((arguments[1] + “”) == “undefined”) format = “yyyy-MM-dd HH:mm:ss”;  
   5.     else format = arguments[1];  
   6.     yi = format.indexOf(”yyyy”);  
   7.     Mi = format.indexOf(”MM”);  
   8.     di = format.indexOf(”dd”);  
   9.     Hi = format.indexOf(”HH”);  
  10.     mi = format.indexOf(”mm”);  
  11.     si = format.indexOf(”ss”);  
  12.     if(yi == -1 || Mi == -1 || di == -1) return null;  
  13.     else{  
  14.         y = parseInt(str.substring(yi, yi+4));  
  15.         M = parseInt(str.substring(Mi, Mi+2));  
  16.         d = parseInt(str.substring(di, di+2));  
  17.     }  
  18.     if(isNaN(y) || isNaN(M) || isNaN(d)) return null;  
  19.     if(Hi == -1 || mi == -1 || si == -1) return new Date(y, M-1, d);  
  20.     else{  
  21.         H = str.substring(Hi, Hi+4);  
  22.         m = str.substring(mi, mi+2);  
  23.         s = str.substring(si, si+2);  
  24.     }  
  25.     if(isNaN(parseInt(y)) || isNaN(parseInt(M)) || isNaN(parseInt(d))) return new Date(y, M-1, d);  
  26.     else return new Date(y, M-1, d,H, m, s);  
  27. }  
  28.    

/*LTrim(string):去除左边的空格*/
代码

   1. function LTrim(str){  
   2.     var whitespace = new String(” \t\n\r”);  
   3.     var s = new String(str);    
   4.  
   5.     if (whitespace.indexOf(s.charAt(0)) != -1){  
   6.         var j=0, i = s.length;  
   7.         while (j < i && whitespace.indexOf(s.charAt(j)) != -1){  
   8.             j++;  
   9.         }  
  10.         s = s.substring(j, i);  
  11.     }  
  12.     return s;  
  13. }  
  14.    

/*RTrim(string):去除右边的空格*/
代码

   1. function RTrim(str){  
   2.     var whitespace = new String(” \t\n\r”);  
   3.     var s = new String(str);  
   4.    
   5.     if (whitespace.indexOf(s.charAt(s.length-1)) != -1){  
   6.         var i = s.length - 1;  
   7.         while (i >= 0 && whitespace.indexOf(s.charAt(i)) != -1){  
   8.             i-;  
   9.         }  
  10.         s = s.substring(0, i+1);  
  11.     }  
  12.     return s;  
  13. }  
  14.    

/*Trim(string):去除字符串两边的空格*/
代码

   1. function Trim(str){  
   2.     return RTrim(LTrim(str));  
   3. }

建议继续学习:

  1. 使用SoapHeader实现Soap请求验证    (阅读:4877)
  2. Apache设置帐户验证[.htaccess]    (阅读:2785)
  3. javascript各种各样的验证方法(正则表达式)    (阅读:1642)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
© 2009 - 2024 by blogread.cn 微博:@IT技术博客大学习

京ICP备15002552号-1