隨筆 - 5, 文章 - 0, 評(píng)論 - 20, 引用 - 0
          數(shù)據(jù)加載中……

          普元常用校驗(yàn)?zāi)_本DataFormCheck.js

          /******************************************************/
          /* 文件名:DataFormCheck.js                            */
          /* 功  能:基于自定義屬性的Javascript校驗(yàn)函數(shù)庫     */
          /* 作  者:陳春            */
          /* 日  期:2005-5-11 10:46         */
          /******************************************************/

          /**
          * 目前所支持的校驗(yàn)類型有:
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |  類 型   |  校驗(yàn)函數(shù)       |  描 述           |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |number     |f_check_number(obj)     |數(shù)字             |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |naturalnumber   |f_check_naturalnumber(obj)    |正整數(shù)             |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |integer    |f_check_integer(obj)     |整數(shù)             |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |float     |f_check_float(obj)      |實(shí)數(shù)             |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |zh      |f_check_zh(obj)      |漢字             |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |lowercase    |f_check_lowercase(obj)     |小寫英文字母            |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |uppercase    |f_check_uppercase(obj)     |大寫英文字母            |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |letter     |f_check_letter(obj)     |英文字母             |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |ZhOrNumOrLett   |f_check_ZhOrNumOrLett(obj)    |漢字、字母、數(shù)字組成的字符串        |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |IP      |f_check_IP(obj)      |計(jì)算機(jī)的IP地址           |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |port     |f_check_port(obj)      |計(jì)算機(jī)的IP地址的端口號(hào)         |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |URL     |f_check_URL(obj)      |網(wǎng)頁地址             |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |email     |f_check_email(obj)      |電子郵件地址            |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |mobile     |f_check_mobile(obj)     |移動(dòng)電話號(hào)碼            |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |phone     |f_check_phone(obj)      |電話號(hào)碼             |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |zipcode    |f_check_zipcode(obj)     |郵政編碼             |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |userID     |f_check_userID(obj)     |用戶ID,可以為數(shù)字、字母、下劃線的組合,第一個(gè)字符不能為數(shù)字, |
          |      |          |且總長度不能超過20。          |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |IDno     |f_check_IDno(obj)      |身份證             |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |formatStr(reg)   |f_check_formatStr(obj)     |符合某正則表達(dá)式的字符串。指定的字符串中不要包含"http://",也不需要引號(hào). |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |date(yyyyMMdd)   |f_check_date(obj)      |指定格式的日期數(shù)據(jù),目前支持yyyy年MM月dd日,yyyy-MM-dd,  |
          |      |          |yyyy/MM/dd,yyyyMMdd         |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |time(yyyyMMddHHmmss) |f_check_time(obj)      |指定格式的時(shí)間數(shù)據(jù),目前支持yyyy年MM月dd日HH時(shí)mm分ss秒,  |
          |      |          |yyyy-MM-dd HH:mm:ss,yyyy/MM/dd HH:mm:ss,yyyyMMddHHmmss |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |double(len,prc)  |f_check_double(obj)     |帶長度和精度的數(shù)字          |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |interval(min,max)  |f_check_interval(obj)     |在某區(qū)間內(nèi)的數(shù)字,"-"代表負(fù)無窮,"+"代表正無窮。    |
          +-----------------------+---------------------------------------+-------------------------------------------------------+
          |      |checkIntervalObjs(obj1 , obj2)   |校驗(yàn)2個(gè)表單域中的值是否滿足obj1小于obj2      |
          +-----------------------+---------------------------------------+-------------------------------------------------------+

          */

          /**
          * 取得字符串的字節(jié)長度
          */
          function strlen(str)
          {
           var i;
           var len;
           
           len = 0;
           for (i=0;i<str.length;i++)
           {
            if (str.charCodeAt(i)>255) len+=2; else len++;
           }
           return len;
          }

          /*
          * 判斷是否為數(shù)字,是則返回true,否則返回false
          */
          function f_check_number(obj)
          {    
           if (/^\d+$/.test(Math.abs(obj.value)))
           {
              return true;
           }
           else
           {
              f_alert(obj,"請(qǐng)輸入數(shù)字");
              return false;
           }
          }

          /*
          * 判斷是否為正整數(shù),是則返回true,否則返回false
          */
          function f_check_naturalnumber(obj)
          {    
           var s = obj.value;
           if (/^[0-9]+$/.test( s ) && (s > 0))
           {
              return true;
           }
           else
           {
            f_alert(obj,"請(qǐng)輸入正整數(shù)");
               return false;
           }
          }

          /*
          * 判斷是否為整數(shù),是則返回true,否則返回false
          */
          function f_check_integer(obj)
          {    
           if (/^(\+|-)?\d+$/.test( obj.value ))
           {
              return true;
           }
           else
           {
            f_alert(obj,"請(qǐng)輸入整數(shù)");
               return false;
           }
          }

          /*
          * 判斷是否為實(shí)數(shù),是則返回true,否則返回false
          */
          function f_check_float(obj)
          {    
           if (/^(\+|-)?\d+($|\.\d+$)/.test( obj.value ))
           {
              return true;
           }
           else
           {
            f_alert(obj,"請(qǐng)輸入實(shí)數(shù)");
              return false;
           }
          }

          /*
          * 校驗(yàn)數(shù)字的長度和精度
          */
          function f_check_double(obj){
           var numReg;
           var value = obj.value;
           if(Trim(value).length != 0){
            if(!f_check_float(obj)) return;
           } 
           var strValueTemp, strInt, strDec; 
           var dtype = obj.eos_datatype;
           var pos_dtype = dtype.substring(dtype.indexOf("(")+1,dtype.indexOf(")")).split(",");
           var len = pos_dtype[0], prec = pos_dtype[1];
           try
           {  
            numReg =/[\-]/;
            strValueTemp = value.replace(numReg, "");
            numReg =/[\+]/;
            strValueTemp = strValueTemp.replace(numReg, "");
            //整數(shù)
            if(prec==0){
             numReg =/[\.]/;
             if(numReg.test(value) == true){
              f_alert(obj, "輸入必須為整數(shù)類型");
              return false; 
             }   
            }  
            if(strValueTemp.indexOf(".") < 0 ){
             if(strValueTemp.length >( len - prec)){
              f_alert(obj, "整數(shù)位不能超過"+ (len - prec) +"位");
              return false;
             }  
            }else{
             strInt = strValueTemp.substr( 0, strValueTemp.indexOf(".") );  
             if(strInt.length >( len - prec)){
              f_alert(obj, "整數(shù)位不能超過"+ (len - prec) +"位");
              return false;
             }
             strDec = strValueTemp.substr( (strValueTemp.indexOf(".")+1), strValueTemp.length ); 
             if(strDec.length > prec){
              f_alert(obj, "小數(shù)位不能超過"+  prec +"位");
              return false;
             }  
            }  
            return true;
           }catch(e){
            alert("in f_check_double = " + e);
            return false;
           } 
          }

          /*
          * 校驗(yàn)數(shù)字的最小最大值
          * 返回bool
          */
          function f_check_interval(obj)
          {
           var value = parseFloat(obj.value);

           var dtype = obj.eos_datatype;
           var pos_dtype = dtype.substring(dtype.indexOf("(")+1,dtype.indexOf(")")).split(",");
           
           var minLimit = pos_dtype[0];
           var maxLimit = pos_dtype[1];
           var minVal = parseFloat(pos_dtype[0]);
           var maxVal = parseFloat(pos_dtype[1]);
           
           if(isNaN(value))
           {
            f_alert(obj, "值必須為數(shù)字");
            return false;
           }
           if((isNaN(minVal) && (minLimit != "-")) || (isNaN(maxVal) && (maxLimit != "+")))
           {
            f_alert(obj, "邊界值必須為數(shù)字或-、+");
            return false;
           }

           if(minLimit == "-" && !isNaN(maxVal))
           {
            if(value > maxVal)
            {
             f_alert(obj, "值不能超過" + maxVal);
             return false;
            }
           }
           
           if(!isNaN(minVal) && maxLimit == "+")
           {  
            if(value < minVal)
            {
             f_alert(obj, "值不能小于" + minVal);
             return false;
            }
           }
           
           if(!isNaN(minVal) && !isNaN(maxVal))
           {
            if(minVal > maxVal)
            {
             f_alert(obj, "起始值" + minVal + "不能大于終止值" + maxVal);
            }else
            {
             if(!(value <= maxVal && value >= minVal))
             {
              f_alert(obj, "值應(yīng)該在" + minVal + "和" + maxVal + "之間");
              return false;
             }
            }
           }
           return true;
          }

          /*
          用途:檢查輸入字符串是否只由漢字組成
          如果通過驗(yàn)證返回true,否則返回false 
          */
          function f_check_zh(obj){
           if (/^[\u4e00-\u9fa5]+$/.test(obj.value)) {
             return true;
           }
           f_alert(obj,"請(qǐng)輸入漢字");
           return false;
          }

          /*
          * 判斷是否為小寫英文字母,是則返回true,否則返回false
          */
          function f_check_lowercase(obj)
          {    
           if (/^[a-z]+$/.test( obj.value ))
           {
              return true;
           }
           f_alert(obj,"請(qǐng)輸入小寫英文字母");
              return false;
          }

          /*
          * 判斷是否為大寫英文字母,是則返回true,否則返回false
          */
          function f_check_uppercase(obj)
          {    
           if (/^[A-Z]+$/.test( obj.value ))
           {
              return true;
           }
           f_alert(obj,"請(qǐng)輸入大寫英文字母");
           return false;
          }

          /*
          * 判斷是否為英文字母,是則返回true,否則返回false
          */
          function f_check_letter(obj)
          {    
           if (/^[A-Za-z]+$/.test( obj.value ))
           {
              return true;
           }
           f_alert(obj,"請(qǐng)輸入英文字母");
           return false;
          }

          /*
          用途:檢查輸入字符串是否只由漢字、字母、數(shù)字組成
          輸入:
           value:字符串
          返回:
           如果通過驗(yàn)證返回true,否則返回false 
          */
          function f_check_ZhOrNumOrLett(obj){    //判斷是否是漢字、字母、數(shù)字組成
           var regu = "^[0-9a-zA-Z\u4e00-\u9fa5]+$";  
           var re = new RegExp(regu);
           if (re.test( obj.value )) {
             return true;
           }
           f_alert(obj,"請(qǐng)輸入漢字、字母或數(shù)字");
           return false;
          }

          /*
          用途:校驗(yàn)ip地址的格式
          輸入:strIP:ip地址
          返回:如果通過驗(yàn)證返回true,否則返回false; 
          */
          function f_check_IP(obj)
          {
              var re=/^(\d+)\.(\d+)\.(\d+)\.(\d+)$/; //匹配IP地址的正則表達(dá)式
           if(re.test( obj.value ))
           {
            if( RegExp.$1 <256 && RegExp.$2<256 && RegExp.$3<256 && RegExp.$4<256) return true;
           }
           f_alert(obj,"請(qǐng)輸入合法的計(jì)算機(jī)IP地址");
           return false;
          }

          /*
          用途:檢查輸入對(duì)象的值是否符合端口號(hào)格式
          輸入:str 輸入的字符串
          返回:如果通過驗(yàn)證返回true,否則返回false 
          */
          function f_check_port(obj)
          {
           if(!f_check_number(obj))
            return false;
           if(obj.value < 65536)
            return true;
           f_alert(obj,"請(qǐng)輸入合法的計(jì)算機(jī)IP地址端口號(hào)");
           return false;
          }

          /*
          用途:檢查輸入對(duì)象的值是否符合網(wǎng)址格式
          輸入:str 輸入的字符串
          返回:如果通過驗(yàn)證返回true,否則返回false 
          */
          function f_check_URL(obj){ 
           var myReg = /^((http:[/][/])?\w+([.]\w+|[/]\w*)*)?$/;
           if(myReg.test( obj.value )) return true;
           f_alert(obj,"請(qǐng)輸入合法的網(wǎng)頁地址");
           return false;
          }

          /*
          用途:檢查輸入對(duì)象的值是否符合E-Mail格式
          輸入:str 輸入的字符串
          返回:如果通過驗(yàn)證返回true,否則返回false 
          */
          function f_check_email(obj){ 
           var myReg = /^([-_A-Za-z0-9\.]+)@([_A-Za-z0-9]+\.)+[A-Za-z0-9]{2,3}$/;
           if(myReg.test( obj.value )) return true;
           f_alert(obj,"請(qǐng)輸入合法的電子郵件地址");
           return false;
          }

          /*
          要求:一、移動(dòng)電話號(hào)碼為11或12位,如果為12位,那么第一位為0
            二、11位移動(dòng)電話號(hào)碼的第一位和第二位為"13"
            三、12位移動(dòng)電話號(hào)碼的第二位和第三位為"13"
          用途:檢查輸入手機(jī)號(hào)碼是否正確
          輸入:
           s:字符串
          返回:
           如果通過驗(yàn)證返回true,否則返回false 
          */
          function f_check_mobile(obj){  
           var regu =/(^[1][3][0-9]{9}$)|(^0[1][3][0-9]{9}$)/;
           var re = new RegExp(regu);
           if (re.test( obj.value )) {
             return true;
           }
           f_alert(obj,"請(qǐng)輸入正確的手機(jī)號(hào)碼");
           return false; 
          }

          /*
          要求:一、電話號(hào)碼由數(shù)字、"("、")"和"-"構(gòu)成
            二、電話號(hào)碼為3到8位
            三、如果電話號(hào)碼中包含有區(qū)號(hào),那么區(qū)號(hào)為三位或四位
            四、區(qū)號(hào)用"("、")"或"-"和其他部分隔開
          用途:檢查輸入的電話號(hào)碼格式是否正確
          輸入:
           strPhone:字符串
          返回:
           如果通過驗(yàn)證返回true,否則返回false 
          */
          function f_check_phone(obj)
          {
           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}$)/;
           var re = new RegExp(regu);
           if (re.test( obj.value )) {
             return true;
           }
           f_alert(obj,"請(qǐng)輸入正確的電話號(hào)碼");
           return false;
          }

          /* 判斷是否為郵政編碼 */
          function f_check_zipcode(obj)
          {
           if(!f_check_number(obj))
            return false;
           if(obj.value.length!=6)
           {
            f_alert(obj,"郵政編碼長度必須是6位");
            return false;
           }
           return true;
          }

          /*
          用戶ID,可以為數(shù)字、字母、下劃線的組合,
          第一個(gè)字符不能為數(shù)字,且總長度不能超過20。
          */
          function f_check_userID(obj)
          {
           var userID = obj.value;
           if(userID.length > 20)
           {
            f_alert(obj,"ID長度不能大于20");
            return false;
           }

           if(!isNaN(userID.charAt(0)))
           {
            f_alert(obj,"ID第一個(gè)字符不能為數(shù)字");
            return false;
           }
           if(!/^\w{1,20}$/.test(userID))
           {
            f_alert(obj,"ID只能由數(shù)字、字母、下劃線組合而成");
            return false;
           }
           return true;
          }

          /*
          功能:驗(yàn)證身份證號(hào)碼是否有效
          提示信息:未輸入或輸入身份證號(hào)不正確!
          使用:f_check_IDno(obj)
          返回:bool
          */
          function f_check_IDno(obj)
          {
           var aCity={11:"北京",12:"天津",13:"河北",14:"山西",15:"內(nèi)蒙古",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:"臺(tái)灣",81:"香港",82:"澳門",91:"國外"};
           
           var iSum = 0;
           var info = "";
           var strIDno = obj.value;
           var idCardLength = strIDno.length; 
           if(!/^\d{17}(\d|x)$/i.test(strIDno)&&!/^\d{15}$/i.test(strIDno))
           {
            f_alert(obj,"非法身份證號(hào)");
            return false;
           }
           
           //在后面的運(yùn)算中x相當(dāng)于數(shù)字10,所以轉(zhuǎn)換成a
           strIDno = strIDno.replace(/x$/i,"a");

           if(aCity[parseInt(strIDno.substr(0,2))]==null)
           {
            f_alert(obj,"非法地區(qū)");
            return false;
           }
           
           if (idCardLength==18)
           {
            sBirthday=strIDno.substr(6,4)+"-"+Number(strIDno.substr(10,2))+"-"+Number(strIDno.substr(12,2));
            var d = new Date(sBirthday.replace(/-/g,"/"))
            if(sBirthday!=(d.getFullYear()+"-"+ (d.getMonth()+1) + "-" + d.getDate()))
            {  
             f_alert(obj,"非法生日");
             return false;
            }

            for(var i = 17;i>=0;i --)
             iSum += (Math.pow(2,i) % 11) * parseInt(strIDno.charAt(17 - i),11);

            if(iSum%11!=1)
            {
             f_alert(obj,"非法身份證號(hào)");
             return false;
            }
           }
           else if (idCardLength==15)
           {
            sBirthday = "19" + strIDno.substr(6,2) + "-" + Number(strIDno.substr(8,2)) + "-" + Number(strIDno.substr(10,2));
            var d = new Date(sBirthday.replace(/-/g,"/"))
            var dd = d.getFullYear().toString() + "-" + (d.getMonth()+1) + "-" + d.getDate();  
            if(sBirthday != dd)
            {
             f_alert(obj,"非法生日");
             return false;
            }
           }
           return true;
          }

          /*
          * 判斷字符串是否符合指定的正則表達(dá)式
          */
          function f_check_formatStr(obj)
          {
           var str = obj.value;
           var dtype = obj.eos_datatype;
           var regu = dtype.substring(dtype.indexOf("(")+1,dtype.indexOf(")")); //指定的正則表達(dá)式
           var re = new RegExp(regu);
           if(re.test(str))
            return true;
           f_alert(obj , "不符合指定的正則表達(dá)式要求");
           return false; 
          }

          /*
          功能:判斷是否為日期(格式:yyyy年MM月dd日,yyyy-MM-dd,yyyy/MM/dd,yyyyMMdd)
          提示信息:未輸入或輸入的日期格式錯(cuò)誤!
          使用:f_check_date(obj)
          返回:bool
          */
          function f_check_date(obj)
          {
           var date = Trim(obj.value);
           if(date.length==0) return true;
           var dtype = obj.eos_datatype;
           if(dtype.indexOf("(")==-1) {f_alert(obj, "請(qǐng)指定日期格式"); return false; }
           var format = dtype.substring(dtype.indexOf("(")+1,dtype.indexOf(")")); //日期格式
           var year,month,day,datePat,matchArray;
           
           if(/^(y{4})(-|\/)(M{1,2})\2(d{1,2})$/.test(format))
            datePat = /^(\d{4})(-|\/)(\d{1,2})\2(\d{1,2})$/;
           else if(/^(y{4})(年)(M{1,2})(月)(d{1,2})(日)$/.test(format))
            datePat = /^(\d{4})年(\d{1,2})月(\d{1,2})日$/;
           else if(format=="yyyyMMdd")
            datePat = /^(\d{4})(\d{2})(\d{2})$/;
           else
           {
            f_alert(obj,"日期格式不對(duì)");
            return false;
           }
           matchArray = date.match(datePat);
           if(matchArray == null)
           {
            f_alert(obj,"日期長度不對(duì),或日期中有非數(shù)字符號(hào)");
            return false;
           }
           if(/^(y{4})(-|\/)(M{1,2})\2(d{1,2})$/.test(format))
           {
            year = matchArray[1];
            month = matchArray[3];
            day = matchArray[4];
           } else
           {
            year = matchArray[1];
            month = matchArray[2];
            day = matchArray[3];
           }
           if (month < 1 || month > 12)
           {    
            f_alert(obj,"月份應(yīng)該為1到12的整數(shù)");
            return false;
           }
           if (day < 1 || day > 31)
           {
            f_alert(obj,"每個(gè)月的天數(shù)應(yīng)該為1到31的整數(shù)");
            return false;
           }    
           if ((month==4 || month==6 || month==9 || month==11) && day==31)
           {
            f_alert(obj,"該月不存在31號(hào)");
            return false;
           }    
           if (month==2)
           {
            var isleap=(year % 4==0 && (year % 100 !=0 || year % 400==0));
            if (day>29)
            {    
             f_alert(obj,"2月最多有29天");
             return false;
            }
            if ((day==29) && (!isleap))
            {    
             f_alert(obj,"閏年2月才有29天");
             return false;
            }
           }
           return true;
          }

          /*
          功能:校驗(yàn)的格式為yyyy年MM月dd日HH時(shí)mm分ss秒,yyyy-MM-dd HH:mm:ss,yyyy/MM/dd HH:mm:ss,yyyyMMddHHmmss
          提示信息:未輸入或輸入的時(shí)間格式錯(cuò)誤
          使用:f_check_time(obj)
          返回:bool
          */
          function f_check_time(obj)
          {
           var time = Trim(obj.value);
           if(time.length==0) return true;
           var dtype = obj.eos_datatype;
           if(dtype.indexOf("(")==-1) {f_alert(obj,"請(qǐng)指定時(shí)間格式"); return false; }
           var format = dtype.substring(dtype.indexOf("(")+1,dtype.indexOf(")")); //日期格式
           var datePat,matchArray,year,month,day,hour,minute,second;

           if(/^(y{4})(-|\/)(M{1,2})\2(d{1,2}) (HH:mm:ss)$/.test(format))
            datePat = /^(\d{4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/;
           else if(/^(y{4})(年)(M{1,2})(月)(d{1,2})(日)(HH時(shí)mm分ss秒)$/.test(format))
            datePat = /^(\d{4})年(\d{1,2})月(\d{1,2})日(\d{1,2})時(shí)(\d{1,2})分(\d{1,2})秒$/;
           else if(format == "yyyyMMddHHmmss")
            datePat = /^(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})$/;
           else
           {
            f_alert(obj,"日期格式不對(duì)");
            return false;
           }
           matchArray = time.match(datePat);
           if(matchArray == null)
           {
            f_alert(obj,"日期長度不對(duì),或日期中有非數(shù)字符號(hào)");
            return false;
           }
           if(/^(y{4})(-|\/)(M{1,2})\2(d{1,2}) (HH:mm:ss)$/.test(format))
           {
            year = matchArray[1];
            month = matchArray[3];
            day = matchArray[4];
            hour = matchArray[5];
            minute = matchArray[6];
            second = matchArray[7];
           } else
           {
            year = matchArray[1];
            month = matchArray[2];
            day = matchArray[3];
            hour = matchArray[4];
            minute = matchArray[5];
            second = matchArray[6];
           }
           if (month < 1 || month > 12)
           {    
            f_alert(obj,"月份應(yīng)該為1到12的整數(shù)");
            return false;
           }
           if (day < 1 || day > 31)
           {   
            f_alert(obj,"每個(gè)月的天數(shù)應(yīng)該為1到31的整數(shù)");
            return false;
           }    
           if ((month==4 || month==6 || month==9 || month==11) && day==31)
           {   
            f_alert(obj,"該月不存在31號(hào)");
            return false;
           }    
           if (month==2)
           {
            var isleap=(year % 4==0 && (year % 100 !=0 || year % 400==0));
            if (day>29)
            {    
             f_alert(obj,"2月最多有29天");
             return false;
            }
            if ((day==29) && (!isleap))
            {    
             f_alert(obj,"閏年2月才有29天");
             return false;
            }
           }
           if(hour<0 || hour>23)
           {
            f_alert(obj,"小時(shí)應(yīng)該是0到23的整數(shù)");
            return false;
           }
           if(minute<0 || minute>59)
           {
            f_alert(obj,"分應(yīng)該是0到59的整數(shù)");
            return false;
           }
           if(second<0 || second>59)
           {
            f_alert(obj,"秒應(yīng)該是0到59的整數(shù)");
            return false;
           }
              return true;
          }
          /*判斷當(dāng)前對(duì)象是否可見*/
          function isVisible(obj){
           var visAtt,disAtt;
           try{
            disAtt=obj.style.display;
            visAtt=obj.style.visibility;
           }catch(e){}
           if(disAtt=="none" || visAtt=="hidden")
            return false;
           return true;
          }
          /*判斷當(dāng)前對(duì)象及其父對(duì)象是否可見*/
          function checkPrVis(obj){
           var pr=obj.parentNode;
           do{
            if(pr == undefined || pr == "undefined") return true;
            else{
             if(!isVisible(pr)) return false;
            }
           }while(pr=pr.parentNode);
           return true;
          }
          /* 彈出警告對(duì)話框,用戶點(diǎn)確定后將光標(biāo)置于出錯(cuò)文本框上, 并且將原來輸入內(nèi)容選中。*/
          function f_alert(obj,alertInfo)
          {
           var caption = obj.getAttribute("eos_displayname");
           var type = obj.getAttribute("type");
           if(caption == null)
            caption = "";
           alert(caption + ":" + alertInfo + "!");
           if(type != null){
            if(type == "text" || type == "TEXT" || type == "textarea" || type == "TEXTAREA")
             obj.select();
           }
           if(isVisible(obj) && checkPrVis(obj))
            obj.focus();
          }

          /**
          * 檢測字符串是否為空
          */
          function isnull(str)
          {
              var i;
              if(str.length == 0)
            return true;
              for (i=0;i<str.length;i++)
              {
                  if (str.charAt(i)!=' ')
             return false;
              }
              return true;
          }

          /**
          * 檢測指定文本框輸入是否合法。
          * 如果用戶輸入的內(nèi)容有錯(cuò),則彈出提示對(duì)話框,
          * 同時(shí)將焦點(diǎn)置于該文本框上,并且該文本框前面
          * 會(huì)出現(xiàn)一個(gè)警告圖標(biāo)(輸入正確后會(huì)自動(dòng)去掉)。
          */
          function checkInput(object)
          {
           var image;
           var i;
           var length;

           if(object.eos_maxsize + "" != "undefined") length = object.eos_maxsize;
           else length = 0;

           if ( isnull(object.value)) return true;

           /* 長度校驗(yàn) */
           if(length != 0 && strlen(object.value) > parseInt(length)) {
             f_alert(object, "超出最大長度" + length);
             return false;
           }
           /* 數(shù)據(jù)類型校驗(yàn) */
           else {
            if (object.eos_datatype + "" != "undefined")
            {  

             var dtype = object.eos_datatype;
             var objName = object.name;
             //如果類型名后面帶有括號(hào),則視括號(hào)前面的字符串為校驗(yàn)類型
             if(dtype.indexOf("(") != -1)
              dtype = dtype.substring(0,dtype.indexOf("("));
             //根據(jù)頁面元素的校驗(yàn)類型進(jìn)行校驗(yàn)
             try{
              if(eval("f_check_" + dtype + "(object)") != true)
               return false;
             }catch(e){return true;}
             /* 如果form中存在name前半部分相同,并且同時(shí)存在以"min"和"max"結(jié)尾的表單域,
              那么視為按區(qū)間查詢。即"min"結(jié)尾的表單域的值要小于等于"max"結(jié)尾的表單域的值。 */
             if(objName.substring((objName.length-3),objName.length)=="min")
             {
              var objMaxName = objName.substring(0, (objName.length-3)) + "max";
              if(document.getElementById(objMaxName) != undefined && document.getElementById(objMaxName) != "undefined" )
              {
               if(checkIntervalObjs(object, document.getElementById(objMaxName)) != true)
                return false;     
              }
             }   
            }
           }
           return true;
          }

          /* 檢測表單中所有輸入項(xiàng)的正確性,一般用于表單的onsubmit事件 */
          function checkForm(myform)
          {
           var i;
           for (i=0;i<myform.elements.length;i++)
           {
               /* 非自定義屬性的元素不予理睬 */  
            if (myform.elements[i].eos_displayname + "" == "undefined") continue;
            /* 非空校驗(yàn) */
            if (myform.elements[i].eos_isnull=="false" && isnull(myform.elements[i].value)){
             f_alert(myform.elements[i],"不能為空");
             return false;
            }  
            /* 數(shù)據(jù)類型校驗(yàn) */
            if (checkInput(myform.elements[i])==false)
             return false;    
           }
           return true;
          }

          /**
          * 校驗(yàn)兩個(gè)表單域數(shù)據(jù)的大小,目前只允許比較日期和數(shù)字。
          * @param obj1 小值表單域
          * @param obj2 大值表單域
          */
          function checkIntervalObjs(obj1 , obj2)

           var caption1 = obj1.eos_displayname;
           var caption2 = obj2.eos_displayname;
           var val1 = parseFloat(obj1.value);
           var val2 = parseFloat(obj2.value);
           var dtype1 = obj1.eos_datatype;
           var dtype2 = obj2.eos_datatype;
           
           // 非自定義屬性的元素不予理睬
           if (obj1.eos_displayname + "" == "undefined" || obj2.eos_displayname + "" == "undefined") {
            return false;
           }
           // 日期類型的比較
           if((dtype1.indexOf("date")!=-1 && dtype2.indexOf("date")!=-1) ||
            (dtype1.indexOf("time")!=-1 && dtype2.indexOf("time")!=-1)){
            if(Trim(obj1.value.length)==0 || Trim(obj2.value.length)==0) return true;
            var format1 = dtype1.substring(dtype1.indexOf("(")+1,dtype1.indexOf(")")); //日期時(shí)間格式
            var format2 = dtype2.substring(dtype2.indexOf("(")+1,dtype2.indexOf(")")); //日期時(shí)間格式
            val1 = getDateByFormat(obj1.value, format1);
            val2 = getDateByFormat(obj2.value, format2);
            if(val1 > val2){
             obj2.select();
             if(isVisible(obj2) && checkPrVis(obj2)) obj2.focus();
             alert(caption1 + "的起始日期不能大于其終止日期!");
             return false;
            }
           } 
           // 數(shù)字類型的比較
           if((isNaN(val1) && !isnull(val1)) || (isNaN(val2) && !isnull(val2))){
            alert(caption1 + "的值不全為數(shù)字則不能比較!");
            return false;
           }
           if(val1 > val2){
            obj2.select();
            if(isVisible(obj2) && checkPrVis(obj2))
             obj2.focus();
            alert(caption1 + "的起始值不能大于其終止值!");
            return false;
           }
           return true;
          }
          //校驗(yàn)表單并提交
          function check(frm){
           if(checkForm(frm) == false) return;
           else frm.submit();     
          }
          //表單數(shù)據(jù)重置
          function resetData(frm){
           frm.reset();
          }

          /*根據(jù)日期格式,將字符串轉(zhuǎn)換成Date對(duì)象。
          格式:yyyy-年,MM-月,dd-日,HH-時(shí),mm-分,ss-秒。
          (格式必須寫全,例如:yy-M-d,是不允許的,否則返回null;格式與實(shí)際數(shù)據(jù)不符也返回null。)
          默認(rèn)格式:yyyy-MM-dd HH:mm:ss,yyyy-MM-dd。*/
          function getDateByFormat(str){
           var dateReg,format;
           var y,M,d,H,m,s,yi,Mi,di,Hi,mi,si;
           if((arguments[1] + "") == "undefined") format = "yyyy-MM-dd HH:mm:ss";
           else format = arguments[1];
           yi = format.indexOf("yyyy");
           Mi = format.indexOf("MM");
           di = format.indexOf("dd");
           Hi = format.indexOf("HH");
           mi = format.indexOf("mm");
           si = format.indexOf("ss");
           if(yi == -1 || Mi == -1 || di == -1) return null;
           else{
            y = parseInt(str.substring(yi, yi+4),10);
            M = parseInt(str.substring(Mi, Mi+2),10);
            d = parseInt(str.substring(di, di+2),10);
           }
           if(isNaN(y) || isNaN(M) || isNaN(d)) return null;
           if(Hi == -1 || mi == -1 || si == -1) return new Date(y, M-1, d);
           else{
            H = str.substring(Hi, Hi+4);
            m = str.substring(mi, mi+2);
            s = str.substring(si, si+2);
           }
           if(isNaN(parseInt(y)) || isNaN(parseInt(M)) || isNaN(parseInt(d))) return new Date(y, M-1, d);
           else return new Date(y, M-1, d,H, m, s);
          }

          /*LTrim(string):去除左邊的空格*/
          function LTrim(str){
              var whitespace = new String(" \t\n\r");
              var s = new String(str);  

              if (whitespace.indexOf(s.charAt(0)) != -1){
                  var j=0, i = s.length;
                  while (j < i && whitespace.indexOf(s.charAt(j)) != -1){
                      j++;
                  }
                  s = s.substring(j, i);
              }
              return s;
          }
          /*RTrim(string):去除右邊的空格*/
          function RTrim(str){
              var whitespace = new String(" \t\n\r");
              var s = new String(str);
              if (whitespace.indexOf(s.charAt(s.length-1)) != -1){
                  var i = s.length - 1;
                  while (i >= 0 && whitespace.indexOf(s.charAt(i)) != -1){
                      i--;
                  }
                  s = s.substring(0, i+1);
              }
              return s;
          }
          /*Trim(string):去除字符串兩邊的空格*/
          function Trim(str){
              return RTrim(LTrim(str));
          }

          posted on 2007-09-14 16:16 primeton 閱讀(1320) 評(píng)論(0)  編輯  收藏


          只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 易门县| 永嘉县| 河津市| 嘉义县| 南投县| 柘荣县| 武强县| 天峨县| 敦化市| 鲁山县| 府谷县| 徐水县| 启东市| 洛宁县| 大邑县| 连州市| 洛川县| 陵川县| 湖州市| 赤壁市| 章丘市| 浙江省| 教育| 噶尔县| 嘉峪关市| 元阳县| 廉江市| 阿拉善左旗| 蕲春县| 迁安市| 丹棱县| 洛宁县| 扎囊县| 怀来县| 南溪县| 肃北| 磐石市| 益阳市| 广南县| 佳木斯市| 重庆市|