表单验证类


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<style type="text/css">
<!--
.error {
    font-family: Verdana, Arial, Helvetica, sans-serif;
    font-size: 12px;
    color: #FF0000;
}
-->
</style>
<script language="javascript" type="text/javascript">
String.prototype.trim = function(){
    return this.replace(/(^\s*)|(\s*$)/g, "");
}
var FormValidate = {};
(function($){
    var Require = /.+/;
    var Email = /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/;
    var Phone = /^((\(\d{2,3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$/;
    var Url = /^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"\"])*$/;
    var QQ = /^[1-9]\d{4,8}$/;
    var Num = "$.$checkNumber('Number',obj,rule)";
    var Int = "$.$checkNumber('Int',obj,rule)";
    var Double = "$.$checkNumber('Double',obj,rule)";
    var English = /^[A-Za-z]+$/;
    var Chinese =  /^[\u0391-\uFFE5]+$/;
    var Username = "$.$checkUsername(obj,rule)";
    var Filter = "$.$doFilter(obj,rule)";
    var Date = "$.$isDate(obj, rule)";
    var Repeat = "$.$repeat(form,obj,rule)";
    var Range = "getAttribute('min') < (value|0) && (value|0) < getAttribute('max')";
    var Compare = "$.$compare(value,getAttribute('operator'),getAttribute('to'))";
    var Custom = "$.$regexp.test(obj.value)";
    var Group = "$.$mustChecked(obj,rule)";
    
    $.onPass = null;
    $.onUnpass = null;
    
    var errList = [];
    
    $.$validate = function(form,rules,mode){
        errList.length = 0;
        
        mode = mode || 1;
        /*----------------------------
        1,全部检查,并alert
        2,一个一个检查,并alert,focus
        3,调用自定义事件 onPassFun验证通过时调用,onUnpassFun未通过时调用。
        ----------------------------*/        
        
        var f,rule;
        for(var i=0;i<rules.length;i++){
            rule = rules[i];
            if(rule == undefined) continue;
            
            f = $.$check(form,rule);
            
            if(mode == 2 && f === false){
                alert(rule.msg);
                try{form[rule.name].select();}catch(e){};
                try{
                    form[rule.name].focus();
                }catch(e){
                    form[rule.name][0].focus();
                }
                return false;
            }else if(mode == 3 && f === true){
                typeof($.onPass) == "function" ? $.onPass(form[rule.name],rule) : null;
            }else if(mode == 3 && f === false){
                $.$addError(rule);
                typeof($.onUnpass) == "function" ? $.onUnpass(form[rule.name],rule) : null;
            }            
        }
        
        if(mode == 1 && errList.length != 0){
            alert($.$errToString());
            return false;
        }else if(mode == 1){
            return true;
        }else if(mode == 3 && errList.length !=0){
            return false;    
        }else if(mode == 3){
            return true;
        }        
    }
    
    
    $.$check = function(form,rule){
        if(typeof rule.name == "string")
            obj = form[rule.name];
        else
            return null;
        
        if(obj == undefined) return null;// Note :not return false!
        //如果不是必填项,radio,checkbox,option可不向下检查。
        //如果不是必填项,除radio,checkbox,option外,如果值为空的话,可不向下检查。
        if(!(rule.required == true || rule.type=="Require") && (obj.length != undefined || obj.value == "")){
            //if(rule.required != true && (obj.length != undefined || obj.value == "")){
            //alert(rule.name + " " + rule.required + " " + obj.length);
            return true;
        }else if(rule.required == true && obj.length == undefined && !eval(Require.test(obj.value.trim()))){
            $.$addError(rule);
            return false;
        }
        
        if(rule.type == undefined && rule.required !== true) return;
        var type = rule.type
        
        switch(type){
            case "Date" :
            case "Repeat" :
            case "Range" :
            case "Compare" :
            case "Custom" :
            case "Group" :
            case "Limit" :
            case "LimitB" :
            case "SafeString" :
            case "Filter" :
            case "Int":
            case "Double":
            case "Num":
            case "Username":
            case "Repeat":
                if(!eval(eval(type))){
                    $.$addError(rule);
                    return false;
                }else return true;
                break;
            default :
                if(type && !eval(type).test(obj.value)){
                    $.$addError(rule);
                    return false;
                }else{
                    if(type == "Require" || rule.required == true){
                        var min = (typeof rule.min != "number") ? 1 : rule.min;
                        var max = (typeof rule.max != "number") ? "" : rule.max;
                        var reg = new RegExp("^.{" + min + "," + max + "}$");
                        
                        //Textarea 换行
                        //IE,opera /r
                        //FF,Safari /n
                        if(reg.test(obj.value.replace(/[\r|\n]/g,"").trim())){
                            return true;
                        }else{
                            $.$addError(rule);
                            return false;
                        }
                    }else
                        return true;
                }
                break;
        }
    }
    
    
    $.$isDate = function(obj,rule){
        var r = obj.value.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/);
        if(r==null) return false;
        var d = new Date(r[1], r[3]-1, r[4]);
        return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]);        
    }
    
    
    $.$mustChecked = function(obj,rule){
        var o;
        var min_ = rule.min || 1 ,max_ = rule.max || obj.length;
        
        var cn = 0;
        
        for(var i=0;o = obj[i];i++){
            if(o.checked != undefined){//Radio,CheckBox
                if(o.checked)
                    cn++;
            }else{
                var noSelected = rule.noSelected || "";
                if(o.selected && noSelected == o.value) return false;
                else if(o.selected) cn++;
            }
        }
        
        if(cn >= min_ && cn <= max_ ) return true;
        else return false;
    }
    
    
    
    $.$checkNumber = function(type,obj,rule){
        var f;
        switch(type){
            case "Int":
                f =  /^[-\+]?\d+$/.test(obj.value);
                break;
            case "Double":
                f = /^[-\+]?\d+(\.\d+)?$/.test(obj.value);
                break;
            case "Number":
                f = !isNaN(Number(obj.value));
                break;
        }
        
        if(!f) return false;
        
        var min = (typeof rule.min != "number") ? Number.NEGATIVE_INFINITY : rule.min;
        var max = (typeof rule.max != "number") ? Number.POSITIVE_INFINITY : rule.max;
        
        
        //var min = rule.min | Number.NEGATIVE_INFINITY, max = rule.max | Number.POSITIVE_INFINITY;
        // 0 | null = 0   'a' | -2 = -2   -2 | 'a' = -2    'a' | 'a' = 0
        //用这个来判断数字。还可以。
        
        if(obj.value >= min && obj.value <= max)
            return true;
        else
            return false;
    }
    
    
    $.$checkUsername = function(obj,rule){
        var min = rule.min || 3 ,max = rule.max || "";
        var reg = new RegExp("^\\w{" + min + "," + max + "}$","i");
        return reg.test(obj.value);
    }
    
    $.$doFilter = function(obj, rule){
        return new RegExp("^.+\.(?=EXT)(EXT)$".replace(/EXT/g, rule.accept.split(/\s*,\s*/).join("|")), "gi").test(obj.value);
    }
    
    $.$repeat = function(form,obj,rule){
        return form[rule.to].value == obj.value;
    }
    
    $.$addError = function(rule){
        errList.push(rule);
    }
    
    $.$errToString = function(){
        var t = "",rule;
        for(var i=0;rule = errList[i];i++)
            t += (i + 1) + ". " + rule.msg + "\n";
        
        return t;
    }
})(FormValidate)
</script>
</head>
<body>
<form name="testForm" action="?" method="post" enctype="multipart/form-data" onsubmit="return vControl('CHECKFORM',this)">
<div>A:<input type="text" name="a" /></div>
<div>B:<input type="text" name="b"  /></div>
<div>C:<input type="text" name="c" /></div>
<div>D:<input type="text" name="d" /></div>
<div>E:<input type="text" name="e" /></div>
<div>F:<input type="radio" name="f[]" id="radio" value="radio" /><input type="radio" name="f[]" id="radio2" value="radio2" /></div>
<div>
g:
<select id="g" name="g">
    <option></option>
    <option value="a">a</option>
    <option value="b">b</option>
    <option value="c">c</option>
    <option value="d">d</option>
    <option value="e">e</option>
</select>
</div>
<div>H: <input type="file" name="h" id="h" /></div>
<div>I:<input name="i" type="text" /></div>
<div>J:<textarea name="j" id="j" cols="45" rows="5"></textarea></div>
  <input type="submit" name="button" id="button" value="提交1" onclick="mode=1" />
  <input type="submit" name="button2" id="button2" value="提交2" onclick="mode=2" />
  <input type="submit" name="button3" id="button3" value="提交3" onclick="mode=3" />
</form>
</body>
</html>
<script language="javascript" type="text/javascript">
var form = document.forms["testForm"];
var rules = [
    {name:"a",    required:true,        min:5,            msg:"A 是一个必填字段,长度必须大于等于5"},
    {name:"b",    type:"Require",        max:5,            msg:"B是一个必填字段,长度必须小于等于5"},
    {name:"c",    type:"Int",            min:10,            max:20,        msg:"如果填C的话,C必须是一个整数,小于20大于10"},
    {name:"d",    required:true,        type:"Num",        min:-10,    max:10,        msg:"d是一个必选项,其值必须在-10到10之间"},
    {name:"e",    required:true,        type:"Chinese",    msg:"E只能输入汉字"},
    {name:"f[]",type:"Group",        required:true,    msg:"请选择一个F"},
    {name:"g",    type:"Group",        required:true,    noSelected:"a",            msg:"g是一个必选项,其值不能选a"},
    {name:"h",    type:"Filter",        accept:"gif|jpg|png",        msg:"H只接受 gif,jpg,png,可以不填!"},
    {name:"i",    required:true,        type:"Repeat",    to:"a",        msg:"i的值必须等于a的值"},
    {name:"j",    required:true,        min:5,            max:10,        msg:"j是一个必填项,长度在5到10字符之间"}
];
var mode;
var span_ = document.createElement("SPAN");
    span_.className = "error";
FormValidate.onPass = function(obj,rule){
    obj_ = obj.parentNode || obj[obj.length -1].parentNode;
    try{
        obj_.removeChild(obj_.errorTip);
        obj_.errorTip = null
    }catch(e){}
}
FormValidate.onUnpass = function(obj,rule){
    obj_ = obj.parentNode || obj[obj.length -1].parentNode;
    if(!obj_.errorTip){
        obj_.errorTip = span_.cloneNode(true);
        obj_.appendChild(obj_.errorTip);
        obj_.errorTip.innerHTML = rule.msg;
    }
}
function vControl(pChoice,pParm){
    switch(pChoice){
        case "CHECKFORM":
            //Validator.validate(pParm,rules)的效果等同于mode的值为:1
            //如果mode为3时,会执行onPass或onUnpass事件
            f = FormValidate.$validate(pParm,rules,mode);
            if(f===false)
                return false;
            else
                return true;
            break;
    }
}
</script>

文章来自: 本站原创
引用通告: 查看所有引用 | 我要引用此文章
Tags:
相关日志:
评论: 0 | 引用: 0 | 查看次数: 520
发表评论
昵 称:
密 码: 游客发言不需要密码.
内 容:
验证码: 验证码
选 项:
虽然发表评论不用注册,但是为了保护您的发言权,建议您注册帐号.
字数限制 20 字 | UBB代码 关闭 | [img]标签 关闭