天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

JQuery 簡便實現(xiàn)頁面元素數(shù)據(jù)驗證功能

ASP.NET提供了豐富的數(shù)據(jù)驗證控件,但這個驗證功能都必須運用在服務(wù)器控件中;在復(fù)合驗證數(shù)據(jù)時使用也不是很方便(雖然拖放控件很方便,但拖放數(shù)增多和設(shè)置相關(guān)屬性就變得很麻煩的事情)。為了更方便靈活地實現(xiàn)驗證功能,于是采用了JQuery編寫了一個簡單驗證組件,在使用時只需要簡單的描述一下驗證規(guī)則,并不需要寫一句JavaScript就可以實現(xiàn)具備ASP.NET驗證控件的功能(當然頁面要引入相關(guān)JavaScript文件)。
功能目標
       通過簡單的自定義屬性值描述具體的驗證功能,當Form提交自動攔載執(zhí)行驗證功能。如果所有成員驗證成功就提交,否則取消提交。
       簡單使用描述: 
       復(fù)制代碼 代碼如下:
<input id="Text1" type="text" validator="type:string;nonnull:true;tip:請輸入用戶名!;tipcontrol:nametip" /> 
       <input id="Text2" type="text" validator="type:date;nonnull:true;tip:請輸入正確的出生日期!;tipcontrol:birthtip;min:1950-1-1;max:2000-1-1" /> 

實現(xiàn)要點
       利用JQuery提供的素元查找功能,方便查找出需要驗證的元素對象;通過$(document).ready事件進很驗證代碼的初始化和執(zhí)行的切入工作。
       定義驗證規(guī)則描述屬性,在初始化時對相關(guān)驗證描述進行分解和集成處理。
       攔載Form提交過程進行驗證處理,根據(jù)情況確定是否提交數(shù)據(jù)。
       元素對象在發(fā)生onchange事件時自動執(zhí)行驗證處理功能。
       通過alert和自定義區(qū)域顯示錯誤信息。
具體JavaScript代碼
       實現(xiàn)代碼并不復(fù)雜只有幾百行,由于相關(guān)代碼比較簡單所以沒有編寫注解.
具體代碼:
復(fù)制代碼 代碼如下:
// JScript 文件 
//<validator> 
//type:int|number|date|string 
//nonnull:true|false 
//regex:^[-/+]?/d+$ 
//min:0 
//max:999999999 
//campare:id 
//comparetype:eq,neq,leq,req,le,ri 
//tipcontrol: 
//tip: 
//</validator> 
var ErrorMessage; 
function FormValidate(form) 

    ErrorMessage=''; 
    var legality,items; 
    legality = true; 
    items = $(form).find("input[@validator]"); 
    for(var i =0;i< items.length;i++) 
    { 
       if(legality) 
       { 
            legality = OnItemValidator($(items[i])); 
       } 
       else 
       { 
            OnItemValidator($(items[i]));     
       } 
    } 
    items = $(form).find("textarea[@validator]"); 
    for(var i =0;i< items.length;i++) 
    { 
       if(legality) 
       { 
            legality = OnItemValidator($(items[i])); 
       } 
       else 
       { 
            OnItemValidator($(items[i]));     
       } 
    } 
    items = $(form).find("select[@validator]"); 
    for(var i =0;i< items.length;i++) 
    { 
       if(legality) 
       { 
            legality = OnItemValidator($(items[i])); 
       } 
       else 
       { 
            OnItemValidator($(items[i]));     
       } 
    } 
    if(!legality) 
    { 
        if(ErrorMessage !='') 
            alert(ErrorMessage); 
    } 
    return legality; 

function CreateValObject(validator) 

    var valobj = {  type:'string', 
                    nonnull:false, 
                    regex:null, 
                    min:null, 
                    max:null, 
                    campare:null, 
                    comparetype:null, 
                    tipcontrol:null, 
                    tip:null}; 
    var properties; 
    var execute; 
    var namevalue; 
    properties = validator.split(';'); 
    for(i=0;i<properties.length;i++) 
    { 
        namevalue = properties[i].split(':'); 
        execute ="valobj." + namevalue[0] +'=/''+ namevalue[1]+'/';'; 
        eval(execute); 
    } 
    return valobj; 

function OnItemValidator(control) 

    var regex,maxvalue,minvalue,cvalue; 
    var valobj = CreateValObject(control.attr('validator')); 
    var value = control.val(); 
    value = ValidatorConvert(value,valobj.type); 
    if(valobj.nonnull=="true") 
    { 
        if(value == null || value=="") 
        { 
            ValidatorError(valobj); 
            return false; 
        } 
    } 
    else 
    { 
        if(value == null || value=="") 
            return true; 
    } 
    if(valobj.regex != null) 
    { 
        regex =new RegExp(valobj.regex); 
        if(value.match(regex) == null) 
        { 
            ValidatorError(valobj); 
            return false; 
        } 
    } 
    if(valobj.min != null) 
    { 
        minvalue = ValidatorConvert(valobj.min,valobj.type); 
        if(!CompareValue(value,minvalue,"req")) 
        { 
            ValidatorError(valobj); 
            return false; 
        } 
    } 
    if(valobj.max != null) 
    { 
        maxvalue = ValidatorConvert(valobj.max,valobj.type); 
        if(!CompareValue(value,maxvalue,"leq")) 
        { 
            ValidatorError(valobj); 
            return false; 
        } 
    } 
    if(valobj.campare != null) 
    { 
        cvalue = $('#' + valobj.campare).val(); 
        cvalue = ValidatorConvert(cvalue,valobj.type); 
        if(!CompareValue(value,cvalue,valobj.comparetype)) 
        { 
            ValidatorError(valobj); 
            return false; 
        } 
    } 
    return true; 

function ValidatorError(valobj) 

    if(valobj.tipcontrol != null) 
        showTip($("#"+ valobj.tipcontrol)); 
    else 
    { 
        if(ErrorMessage !='') 
            ErrorMessage += '/n'; 
        ErrorMessage += valobj.tip; 
    } 

function CompareValue(leftvalue,rightvalue,compareType) 

    if(leftvalue == null || rightvalue == null) 
        return false; 
    if(compareType=="eq") 
    { 
        return leftvalue == rightvalue; 
    } 
    else if(compareType =="neq") 
    { 
        return leftvalue != rightvalue; 
    } 
    else if(compareType =="le") 
    { 
        return leftvalue < rightvalue; 
    } 
    else if(compareType =="leq") 
    { 
        return leftvalue <= rightvalue; 
    } 
    else if(compareType =="ri") 
    { 
        return leftvalue > rightvalue; 
    } 
    else if(compareType =="req") 
    { 
        return leftvalue >= rightvalue; 
    } 
    else 
    { 
        return false; 
    } 

function showTip(control) 

    if(control.attr('show') != 'on') 
    { 
        control.fadeIn("slow"); 
        control.attr('show','on'); 
    } 

function hideTip(control) 

    control.hide(); 
    control.attr('show',''); 

function ValidatorConvert(value, dataType) { 
    var num,exp,m; 
    var year,month,day 
    if(value == null || value =="") 
        return null; 
    if(dataType=="int") 
    { 
        exp=/^[-/+]?/d+$/; 
        if (value.match(exp) == null) 
            return null; 
        num = parseInt(value, 10); 
        return (isNaN(num) ? null : num); 
    } 
    else if(dataType =="number") 
    { 
        exp=/^[-/+]?((/d+)|(/d+/./d+))$/; 
        if (value.match(exp) == null) 
            return null; 
        num = parseFloat(value); 
        return (isNaN(num) ? null : num); 
    } 
    else if(dataType =="date") 
    { 
        exp=/^(/d{4})([-/]?)(/d{1,2})([-/]?)(/d{1,2})$/ 
        m = value.match(exp); 
        if (m == null) 
        { 
            exp=/^(/d{1,2})([-/]?)(/d{1,2})([-/]?)(/d{4})$/ 
            m = value.match(exp); 
            if(m== null) 
                return null; 
            year = m[5]; 
            month = m[1]; 
            day =m[3]; 
        } 
        else 
        { 
            year = m[1]; 
            month =m[3]; 
            day = m[5]; 
        } 
        try 
        { 
            num = new Date(year,month,day); 
        } 
        catch(e) 
        { 
            return null; 
        } 
        return num; 
    } 
    else 
    { 
        return value.toString(); 
    } 

$(document).ready( 
    function(){ 
        $("[@validator]").each(function(i) 
                    { 
                        var valobj = CreateValObject($(this).attr('validator')); 
                        if(valobj.tipcontrol !=null) 
                        { 
                            $('#' + valobj.tipcontrol).addClass('ErrorTip'); 
                            hideTip($('#' + valobj.tipcontrol)); 
                            $("#"+ valobj.tipcontrol).html("<NOBR>"+valobj.tip+"</NOBR>"); 
                        } 
                        $(this).change(function(){ 
                           if(OnItemValidator($(this))) 
                           { 
                                if(valobj.tipcontrol !=null) 
                                { 
                                   hideTip($('#' + valobj.tipcontrol));   
                                } 
                           } 
                           else 
                           { 
                                if(valobj.tipcontrol !=null) 
                                { 
                                   showTip($('#' + valobj.tipcontrol));   
                                } 
                           } 
                        }); 
                     } 
                ); 
          $("form").each(function(id) 
            { 
                $(this).submit(function(){return FormValidate(this)}); 
            } 
            ); 
    } 
); 

下載相關(guān)例程代碼

JavaScript技術(shù)JQuery 簡便實現(xiàn)頁面元素數(shù)據(jù)驗證功能,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 在线亚洲黄色 | 免费在线观看国产 | 公粗挺进了我的密道在线播放贝壳 | 黑人猛挺进小莹的体内视频 | 漂亮妈妈中文字幕版 | 一道精品视频一区二区三区 | 高清不卡伦理电影在线观看 | 日本久久久久亚洲中字幕 | 69久久国产露脸精品国产 | 扒开粉嫩的小缝末成年小美女 | CHINA末成年VIDEO学生 | 毛片手机在线 | 国产在线视频分类精品 | 美目盼兮amy198281 | 免费人成在线观看网站视频 | 国产Av男人的天堂精品良久 | 男人和女人一起愁愁愁很痛 | 中文日产无乱码AV在线观 | 精品久久久久久久高清 | 久久国产免费一区二区三区 | 日韩免费精品视频 | 久久精品国产亚洲AV忘忧草蜜臀 | 白丝美女被狂躁免费漫画 | 黄色三级图片 | 日本久久精品免视看国产成人 | 台湾果冻传媒在线观看 | 免费国产成人手机在线观看 | 国产精品一区二区免费 | 羲义嫁密着中出交尾gvg794 | 最近免费中文字幕完整版HD | 精品无人区麻豆乱码1区2 | 99久久精品全部 | 国产女人与黑人在线播放 | 免费a毛片 | 国产AV电影区二区三区曰曰骚网 | 亚洲免费片 | 国产不卡一卡2卡三卡4卡网站 | 伊人久久精品AV无码一区 | 日本欧美高清一区二区视频 | 总裁呻吟双腿大开男男H | 亚洲高清国产拍精品影院 |