`
songlixiao
  • 浏览: 23238 次
  • 性别: Icon_minigender_1
  • 来自: 青岛
社区版块
存档分类
最新评论

javaScript前台校验jQuery.validate

阅读更多

        做网页表单经常要用到数据校验的功能.JavaScript校验是一种比较常用的手段。最近写页面写得比较多,发现了一个比较好用的js校验框架--jQuery.validate。她是一款基于jquery校验工具,基本可以满足我们大多数的页面校验需要,且支持ajax校验。支持各种自定义的扩展,包括自定义校验规则,自定义错误显示的方式等。

        通过一段时间的使用,感觉用起来还是非常简单的。这里做一下使用方法的简单介绍,而后会介绍一个我自己扩展的一种错误提示方式(感觉默认的信息提示的方式比较一般实在不怎么好看)。
        闲话少说,先说下用法:
        先导入必要的两个js文件

<script type="text/javascript" src="lib/jquery-1.4.2.min.js"></script>   
<script type="text/javascript" src="lib/jquery.validate.js"></script>  
 

 

    另外还有一段css,用来突出显示出错的表单控件和错误信息的显示样式:

input.error { border: 1px dotted red; }    
label.error {    
    color: red;display: none;    
}   
 

         label.error 的display: none是为了让我们可以在页面上任意位置放置显示错误的label以及上面的内容,并在没有进行校验时不显示出来。
        需要的东西都齐了,我们可以为我们的表单元素添加校验了。添加校验的方法总的说有两种:一种写在控件的标签上;另一种写在js脚本中。并且两种方法可混合使用。
        第一种写在标签中的如下:

<input type="text" class="required number" max="10" name="t1"> 

 

         class="required number" 表示必须字段且为数值型,max="10" 表示最大值为10。
        令一种使用JavaScript脚本的写法如下:

<script type="text/javascript">   
$('#test_form').validate({    
rules:{    
 t2 : {required:true,number:true}    
},    
messages:{t2:{required :"这个字段你必须填~~!",number:"这个字段真可以是数字"}}    
});    
</script>  

 

         其中test_form是表单form的id,t2是需要校验的控件的名字。rules后面的json描述的是校验规则,messages是自定义的错误信息。顺便说一句,有时候我们form中控件的name中是带“.”的,比如:user.name,这时候用js脚本定义校验规则时,需要加上引号:”user.name”。
        这两种写法各有利弊,直接写在控件标签上的比较简单直观,相对来说js的写法过于复杂,可灵活性更强。而且有时候我们可能没机会在控件的标签上写规则,假如我们用了标签库,如struts标签库,有些标签我们写上max=“10”这样的东西,标签库将无法解析直接报错。总之,这两种写法jQuery.validate都认识,我们在合适的场景选择合适的方式就可以了。
        另外,如果你想把规则写在控件的标签上,仅仅写上规则是不行的,还需要在页面加载完的时候调用一下$('#test_form').validate();为form添加校验,这样在你点提交按钮的时候就会自动校验了。
        说了这么多,该上个图了,看看校验的效果:

 

        成功了,校验的效果有了,表单也不会被提交。可能有的同学要说了,“要不要这么看看啊?”。这正是我下面要解决的问题。
        我们来自定义一个错误显示的方式,效果如下:

         错误控件突出显示的方式没有改,为了兼容有些浏览器有些控件比如火狐中单选按钮没法标注红框的问题,在每个错误的控件后面放了一个红色的小叉号,另外当鼠标移动到错误控件或者小叉号上时显示错误的信息。
        实现这个效果的主要js代码如下:

function showErrors(){    
        var t = this;    
        for ( var i = 0; this.errorList[i]; i++ ) {    
            var error = this.errorList[i];    
            this.settings.highlight && this.settings.highlight.call( this, error.element, this.settings.errorClass, this.settings.validClass );    
                
            var elename = this.idOrName(error.element);    
            // 错误信息div    
            var errdiv = $('div[htmlfor='+ elename + ']');    
            var errimg = $('img[htmlfor='+ elename + ']');    
            if(errdiv.length == 0){ // 没有div则创建    
                    
                // 纯css不用图片的圆角div,存在在IE6下显示过长的问题    
//              errdiv = $('<div>'     
//              +   '<b class="rtop"><b class="r1"></b><b class="r2"></b><b class="r3"></b><b class="r4"></b></b>'    
//              +   '<span class="errmsg"> </span>'    
//              +   '<b class="rbottom"><b class="r4"></b><b class="r3"></b><b class="r2"></b><b class="r1"></b></b> '    
//              +   '</div> ');    
                    
                // 带图片的圆角div在所有浏览器兼容    
                errdiv = $('<div>'     
                        + '<img src="img/left_icon.gif" width="6" height="24" align="absmiddle" class="fl" />'   
                        + '<div class="errmsgdiv fl errmsg"></div>'   
                        + '<img src="img/right_icon.gif" width="6" height="24" align="absmiddle" class="fl" />'   
                        + '</div>');    
                    
                    
                errdiv.attr({"for":  this.idOrName(error.element), generated: true})    
                .addClass(this.settings.errorClass);    
//              errdiv.css({left : $.getLeft(error.element) + 'px',top : $.getTop(error.element) + 'px'}); // 显示在控件的下面    
                errdiv.appendTo($('body'));    
            }    
            if(errimg.length == 0){ // 没有img则创建    
                errimg = $('<img alt="错误" src="img/unchecked.gif">')    
                errimg.attr({"for":  this.idOrName(error.element), generated: true});    
                errimg.insertAfter(error.element);    
            }    
            errimg.show();    
            errdiv.find(".errmsg").html(error.message || "");    
            // 鼠标放到图片显示错误    
            $(errimg).hover(function(e){    
                $('div[htmlfor="'+ $(this).attr('htmlfor') + '"]').css({left : (e.pageX+20) + 'px',top : (e.pageY+20) + 'px'}); // 显示在鼠标位置偏移20的位置    
                $('div[htmlfor="'+ $(this).attr('htmlfor') + '"]').fadeIn(200);    
            },    
            function(){    
                $('div[htmlfor="'+ $(this).attr('htmlfor') + '"]').fadeOut(200);    
            });    
            // 鼠标放到控件上显示错误    
            $(error.element).hover(function(e){    
                $('div[htmlfor="'+ t.idOrName(this) + '"]').css({left : (e.pageX+20) + 'px',top : (e.pageY+20) + 'px'}); // 显示在鼠标位置偏移20的位置    
                $('div[htmlfor="'+ t.idOrName(this) + '"]').fadeIn(200);    
            },    
            function(){    
                $('div[htmlfor="'+ t.idOrName(this) + '"]').fadeOut(200);    
            });    
        }    
            
        // 校验成功的去掉错误提示    
        for ( var i = 0; this.successList[i]; i++ ) {    
                $('div[htmlfor="'+ this.idOrName(this.successList[i]) + '"]').remove();    
                $('img[htmlfor='+ this.idOrName(this.successList[i]) + ']').hide();    
        }    
            
        // 自定义高亮    
        if (this.settings.unhighlight) {    
            for ( var i = 0, elements = this.validElements(); elements[i]; i++ ) {    
                this.settings.unhighlight.call( this, elements[i], this.settings.errorClass, this.settings.validClass );    
            }    
        }    
    }    
$.extend({    
        getLeft : function(object) {    
            var go = object;    
            var oParent, oLeft = go.offsetLeft;    
            while (go.offsetParent != null) {    
                oParent = go.offsetParent;    
                oLeft += oParent.offsetLeft;    
                go = oParent;    
            }    
            return oLeft;    
        },    
        getTop : function(object) {    
            var go = object;    
            var goHeight = go.height;    
            var oParent, oTop = go.offsetTop;    
            while (go.offsetParent != null) {    
                oParent = go.offsetParent;    
                oTop += oParent.offsetTop;    
                go = oParent;    
            }    
            return oTop + 22;// 之所以加22不加控件高度,为了兼容ie6.    
        }    
});    
// 本地语言    
jQuery.extend(jQuery.validator.messages, {    
        required: "必选字段",    
        remote: "请修正该字段",    
        email: "请输入正确格式的电子邮件",    
        url: "请输入合法的网址",    
        date: "请输入合法的日期",    
        dateISO: "请输入合法的日期 (ISO).",    
        number: "请输入合法的数字",    
        digits: "只能输入整数",    
        creditcard: "请输入合法的信用卡号",    
        equalTo: "请再次输入相同的值",    
        accept: "请输入拥有合法后缀名的字符串",    
        maxlength: jQuery.validator.format("请输入一个长度最多是 {0} 的字符串"),    
        minlength: jQuery.validator.format("请输入一个长度最少是 {0} 的字符串"),    
        rangelength: jQuery.validator.format("请输入一个长度介于 {0} 和 {1} 之间的字符串"),    
        range: jQuery.validator.format("请输入一个介于 {0} 和 {1} 之间的值"),    
        max: jQuery.validator.format("请输入一个最大为 {0} 的值"),    
        min: jQuery.validator.format("请输入一个最小为 {0} 的值")    
}); 
 

         自定义一个showErrors的方法,然后在为表单添加校验时,指定使用这个方法显示错误信息。

$('#test_form').validate({    
rules:{    
 t2 : {required:true,number:true}    
},    
messages:{t2:{required :"这个字段你必须填~~!",number:"这个字段真的可以是数字"}},    
showErrors: showErrors  //使用自定义的错误显示方法    
});  
 

        这样子我们想要的效果就实现了,是不是感觉比原来的样子好多了呢?
        jQuery.validate是一个非常灵活的JavaScript校验框架,上面只是介绍了一下基本的用法和自定义了一个错误显示的样式。一般的表单校验基本可以搞定了,不过一些比较特殊,比如身份证号的校验,页面上FCK编辑器的校验,还是需要我们自己来扩展的。个人感觉这是个很不错的js校验框架,所以介绍给大家,希望有所帮助。

 

 

 

本文附件请到原文地址下载,原文地址:http://www.po-soft.com/blog/slx/1327.html

     提供该文档的机构为 百洋软件研究实验室 ,更多的博客文章可以到 百洋软件研究实验室博客 查看。该文档附件欢迎各位转载,但是在没有获得文章作者许可之前,不得对文章内容或者版权信息进行更改,版权归百洋软件研究实验室所有,仅此声明。

2
2
分享到:
评论

相关推荐

    jquery.validate.min.js

    修改validate的remote校验,支持处理返回格式{success:false,message:"提示消息"}

    jquery.validate表单验证密码完整例子(带密码强度显示)

    `jQuery Validate`是一个非常流行且功能强大的JavaScript库,用于验证HTML表单中的输入数据。这个插件极大地简化了前端数据验证的过程,为开发者提供了丰富的选项和自定义规则。 首先,`jQuery Validate`的核心功能...

    jquery.validate.js校验页面的js与使用方法

    &lt;script type="text/javascript" src="${request.contextPath}/js/common/plug/jquery/jquery.validate.min.js"&gt; &lt;script type="text/javascript" src="${request.contextPath}/js/common/plug/jquery/jquery....

    jQuery验证控件jquery.validate.js使用说明+中文API

    jQuery 验证控件 jquery.validate.js 是一个功能强大且广泛使用的 JavaScript 验证插件,旨在帮助开发者快速实现表单验证功能。下面是 jquery.validate.js 的使用说明和中文 API。 导入 jQuery 库和 jquery....

    jquery.validate表单验证框架详解

    &lt;script type="text/javascript" src="js/jquery.validate.pack.js"&gt; ``` #### 二、基本使用 初始化jQuery.validate插件非常简单,只需在`document.ready()`事件中调用`validate()`方法即可,如: ```javascript ...

    jquery.validate 扩展身份证校验方法

    ### jQuery.validate 扩展身份证校验方法 在前端开发中,对用户输入的数据进行校验是非常重要的一步,它能够帮助开发者提高数据的准确性和安全性。本文将详细介绍如何使用`jQuery.validate`插件来扩展身份证号码的...

    功能强大的jquery.validate表单验证插件

    此外,每个需要校验的表单元素都应该具有唯一的id和name属性,这样便于在JavaScript中通过jQuery选择器选中这些元素,并应用验证规则。 在实际的开发过程中,开发者可以参考诸如百度、网易邮箱、京东等知名互联网...

    jquery.validate的使用说明介绍

    jquery.validate提供了一系列的默认校验规则,这些规则可以覆盖大部分的表单验证需求。这些规则包括: 1. required: true,用于标识必填字段,如果该字段为空,则验证失败。 2. remote: "check.php",利用Ajax方法...

    jquery.validate知识要点

    `jQuery.validate`插件是一种基于jQuery的表单验证工具,它可以帮助开发者快速实现客户端数据校验功能,提高用户体验的同时减少服务器端的压力。该插件支持多种内置验证规则,并且可以方便地扩展自定义规则。 #### ...

    jquery.validate.js 用法

    `jquery.validate.js` 是一款基于jQuery的表单验证插件,能够方便地实现客户端表单验证功能。该插件提供了丰富的内置验证方法,支持必填项检查、邮箱格式验证、URL验证等,并允许用户自定义验证规则与错误提示信息。...

    jquery.validate例子

    3. `jquery.validate.js`:这是`jQuery Validate`的核心文件,包含了所有验证规则、错误消息和验证逻辑。通过引用这个文件,开发者可以轻松地在他们的表单中启用验证。 在`jQuery Validate`的使用中,主要涉及以下...

    jquery.validate表单验证插件使用方法解析

    jquery.validate是jQuery的一个表单验证插件,它提供了丰富、灵活的表单验证功能,可以极大地简化开发者在前端表单验证中的工作。使用jquery.validate可以轻松地对表单中的字段进行验证,确保输入数据符合要求,从而...

    jquery的校验规则(jquery.validate)

    &lt;script src="jquery.validate.js" type="text/javascript"&gt; ``` ### 二、默认验证规则 `jQuery Validate` 提供了一系列内置的验证规则,包括: 1. **required**: 表示字段为必填项。 2. **remote**: 使用 AJAX ...

    jQuery.validate.js+API中文

    `jQuery.validate.js` 是一款非常流行的JavaScript库,专门用于客户端表单验证。它基于jQuery框架,提供了丰富的验证规则和灵活的自定义选项,使得开发者能够轻松地实现各种复杂的验证逻辑。本文将详细介绍`jQuery....

    jquery.validate.js

    而validate.js是jQuery的一个插件,它为表单验证提供了强大而灵活的支持,使得前端数据校验变得更加简单。本文将深入探讨validate.js的核心原理、使用方法以及常见应用场景。 一、validate.js概述 validate.js是...

    jquery validate 信息气泡提示

    在网页开发中,jQuery Validate 是一个非常常用的验证插件,用于对用户输入的数据进行校验,确保数据的有效性和完整性。这个插件可以帮助开发者创建复杂的表单验证规则,提高用户体验,减少服务器端的压力。结合 ...

    jquery.validate_Validation

    &lt;script src="jquery.validate.js" type="text/javascript"&gt; ``` ### 二、默认校验规则 jQuery Validate提供了一系列内置的验证规则,用于检查各种类型的数据格式: 1. **required**:验证字段是否为空,如果为空...

    JQuery+validate校验+messages_zh中文的js库

    `jquery.validate.js` 和 `jquery.validate.min.js` 就是这个插件的源码和压缩版。这个插件提供了一套强大的规则引擎,可以轻松地为表单元素添加验证规则,例如必填、邮箱格式、数字范围等,极大地提高了用户输入...

    jquery.validate.js的用法

    ### jQuery.validate.js 使用详解 #### 一、简介 jQuery.validate.js 是一款强大的 jQuery 插件,主要用于客户端表单验证。该插件简化了原本复杂的表单验证过程,并提供了丰富的内置验证方法,支持自定义验证规则...

    jquery.validate.js表单验证.pdf

    在网页中引入jQuery和validate.js的JavaScript文件,如下所示: ```html &lt;script src="../js/jquery.js" type="text/javascript"&gt; &lt;script src="../js/jquery.validate.js" type="text/javascript"&gt; ``` 接下来,...

Global site tag (gtag.js) - Google Analytics