首页 > 代码库 > jQuery验证插件

jQuery验证插件

学习要点:
1.使用 validate.js 插件
2.默认验证规则
3.validate()方法和选项
4.validate.js 其他功能

 

验证插件(validate.js),是一款验证常规表单数据合法性的插件。使用它,极大的解放了在表单上繁杂的验证过程,并且错误提示显示的完善也增加了用户体验。

 

一.使用 validate.js 插件
官网下载:http://bassistance.de/jquery-plugins/jquery-plugin-validation最重要的文件是validate.js,还有两个可选的辅助文件:additional-methods.js(控件 class方式)和 message_zh.js(提示汉化)文件(实际使用,请使用 min 压缩版) 。

第一步:引入 validate.js
<script type="text/javascript" src="http://www.mamicode.com/js/jquery.validate.js"></script>
第二步:在 JS 文件中执行
$(‘#reg‘).validate();

二.默认验证规则
Validate.js 的默认验证规则的写法有两种形式:1.控件属性方式;2.JS 键值对传参方式。

 

//使用控件方式验证“必填和不得小于两位”

<input type="text" class="required" minlength="2" name="user" id="user" />

注意:默认规则里设置布尔值的,直接写到 class 里即可实现。如果是数字或数组区间,直接使用属性=值的方式即可。而对于错误提示,可以引入中文汉化文件,或直接替换掉即可。
//使用 JS 对象键值对传参方式设置

$(#reg).validate({rules : {    user : {                          //只有一个规则的话,        required : true,             //直接 user : ‘required‘,        minlength : 2,    },},    messages : {        user : {            required : 帐号不得为空!,            minlength : 帐号不得小于 2 位!,        },    }});

 

注意:由于第一种形式不能设置指定的错误提示信息。我们推荐使用第二种形式,第二种形式也避免的 HTML 污染。

 

//所有规则演示

$(#reg).validate({      rules : {        email : {            email : true,        },        url : {            url : true,        },        date : {            date : true,        },        dateIOS : {            dateIOS : true,        },        number : {            number : true,        }         digits : {            digits : true,        },        creditcard : {            creditcard : true,        },        min : {            min : 5,        },        range : {            range : [5, 10],        },        rangelength : {           rangelength : [5,10],        },        notpass : {            equalTo : #pass, //这里的 To 是大写的 T        }    },})

 

三.validate()的方法和选项
除了默认的验证规则外,validate.js 还提供了大量的其他属性和方法供开发者使用。比如,调试属性,错误提示位置一系列比较有用的选项。
//jQuery.format 格式化错误提示

 

$(#reg).validate({    rules : {        user : {            required : true,            minlength : 5,            rangelength : [5,10]        },    },    messages : {        user : {            required : 帐号不得为空!,            minlength : jQuery.format(帐号不得小于{0}位!),            rangelength : jQuery.format(帐号限制在{0}-{1}位!),        },    },});

 

//开启调试模式禁止提交
$(‘#reg‘).validate({
  debug : true,
});


//设置调试模式为默认,可以禁止多个表单提交
$.validator.setDefaults({
  debug : true,   //仍可以正常验证,但是为了方便调试不会提交到指定页面
});


//使用其他方式代替默认提交
submitHandler : function (form) {
  //可以执行 ajax 提交,并且无须 debug:true 阻止提交了
},


//忽略某个字段验证
ignore : ‘#pass‘,


//群组错误提示
groups : {
myerror : ‘user pass‘,
},


//显示群组的错误提示
focusInvalid : false,
errorPlacement : function (error, element) {
  $.each(error, function (index, value) {
    $(‘.myerror‘).html($(‘.myerror‘).html() + $(value).html());
  })
},


//群组错误提示,分开
groups : {
  error_user : ‘user‘,
  error_pass : ‘pass‘
},


//将群组的错误指定存放位置(推荐!!)

errorPlacement : function (error, element) {   error.appendTo(.myerror);},

 

//设置错误提示的 class 名

errorClass : ‘error_list‘,


//设置错误提示的标签
errorElement : ‘p‘,

PS:默认的class名称是“error”,默认的错误提示标签是label。


//统一包裹错误提示

(首先将错误信息标签外面再包裹一层li,然后再html文件中提前设置了错误信息显示元素class为error的ol,这两行代码就将错误信息形成了一个列表样式)
errorLabelContainer : ‘ol.error‘,
wrapper : ‘li‘,


//设置成功后加载的 class
success : ‘success‘,

PS:验证成功之后会在label标签中添加一个sucess类名,然后就可以根据这个设置成功后的的css样式。另外注意:成功之后,对应的input元素里面的class值会有error变为valid,这样也可以根据这个class值设置css样式,样成功后的提示显示在input里面,而不是用success显示在input外面。

 


//使用方法加载 class 并添加文本
success : function (label) {
  label.addClass(‘success‘).text(‘ok‘);
},


//高亮显示有错误的元素,变色式
highlight: function(element, errorClass) {
  $(element).fadeOut(function() {
    $(element).fadeIn()
  })
},

//高亮显示有错误的元素,变色式highlight: function(element, errorClass) {  $(element).css(border, 1px solid red);},//成功的元素移出错误高亮unhighlight : function (element, errorClass) {  $(element).css(border, 1px solid #ccc);},

 

//表单提交时获取信息
invalidHandler : function (event, validator) {
  var errors = validator.numberOfInvalids();
  if (errors) {
    $(‘.myerror‘).html(‘您有‘ + errors + ‘个表单元素填写非法!‘);
  }
},

 

//获取错误提示句柄,不用提交及时获取值showErrors : function (errorMap, errorList) {    var errors = this.numberOfInvalids();    if (errors) {        $(.myerror).html(您有 + errors + 个表单元素填写非法!);    } else {        $(.myerror).hide();    }    this.defaultShowErrors();   //执行默认错误},//获取错误提示句柄,errorListshowErrors : function (errorMap, errorList) {    alert(errorList[0].message);   //得到错误信息    alert(errorList[0].element);   //当前错误的表单元素},

四.validate.js 其他功能
使用 remote:url,可以对表单进行 ajax 验证,默认会提交当前验证的值到远程地址。如果需要提交其他的值,可以使用 data 选项。
//使用 ajax 验证

rules : {    user : {        required : true,        minlength : 2,        remote : user.php,    },},

 

//user.php 内容

<?php    if ($_GET[user] == alex) {        echo false;    } else {        echo true;    }?>

 

 

注意:远程地址只能输出‘true‘或‘false‘,不能输出其他值。
//同时传递多个值到远程端

 

pass : {    required : true,    minlength : 6,    remote : {        url : user.php,        type : POST,        dataType : json,        data : {            user : function () {                return $(#user).val();            },        },    },},

 

//user.php 内容

<?php    if ($_POST[user] != alex || $_POST[pass] != 123456) {        echo false;    } else {        echo true;    }?>

 

validate.js 提供了一些事件触发的默认值,这些值呢,大部分建议是不用更改的。
//取消提交验证
onsubmit : false, //默认是 true
注意: 设置为false 会导致直接传统提交, 不会实现验证功能, 一般是用于keyup/click/blur验证提交。

 

//设置鼠标离开不触发验证
onfocusout : false, //默认为 true


//设置键盘按下弹起不触发验证
onkeyup : false, //默认为 true

注意:只要设置了,在测试的浏览器不管是 false 还是 true 都不触发了。


//设置点击 checkbox 和 radio 点击不触发验证
onclick : false, //默认为 true


//设置错误提示后,无法获取焦点
focusInvalid : false, //默认为 true


//提示错误时,隐藏错误提示,不能和 focusInvalid 一起用,冲突
focusCleanup : true, //默认为 false
如果表单元素设置了 title 值,且 messages 为默认,就会读取 title 值的错误信息,我们可以通过 ignoreTitle : true,设置为 true,屏蔽这一个功能。

ignoreTitle : true, //默认为 false


//判断表单所验证的元素是否全部有效
alert($(‘#reg‘).valid()); //全部有效返回 true


Validate.js 提供了可以单独验证每个表单元素的 rules 方法,不但提供了 add 增加验证,还提供了 remove 删除验证的功能。


//给 user 增加一个表单验证

 

$(#user).rules(add, {    required : true,    minlength : 2,    messages : {        required : 帐号不得为空!,        minlength : jQuery.format(帐号不得小于{0}位!),    }});

 

//删除 user 的所有验证规则
$(‘#user‘).rules(‘remove‘);


//删除 user 的指定验证规则
$(‘#user‘).rules(‘remove‘, ‘minlength min max‘);

 

//添加自定义验证$.validator.addMethod(code, function (value, element) {    var tel = /^[0-9]{6}$/;    return this.optional(element) || (tel.test(value));  }, 请正确填写您的邮政编码);//调用自定义验证rules : {    code : {        required : true,        code : true,    }}