/*
功能:验证×××号码是否有效
提示信息:未输入或输入×××号不正确!
使用: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.