jQuery验证插件

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="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 对象键值对传参方式设置

 1 $('#reg').validate({
 2 rules : {
 3     user : {                          //只有一个规则的话,
 4         required : true,             //直接 user : 'required',
 5         minlength : 2,
 6     },
 7 },
 8     messages : {
 9         user : {
10             required : '帐号不得为空!',
11             minlength : '帐号不得小于 2 位!',
12         },
13     }
14 });

 


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


//所有规则演示

 1 $('#reg').validate({
 2       rules : {
 3         email : {
 4             email : true,
 5         },
 6         url : {
 7             url : true,
 8         },
 9         date : {
10             date : true,
11         },
12         dateIOS : {
13             dateIOS : true,
14         },
15         number : {
16             number : true,
17         }
18          digits : {
19             digits : true,
20         },
21         creditcard : {
22             creditcard : true,
23         },
24         min : {
25             min : 5,
26         },
27         range : {
28             range : [5, 10],
29         },
30         rangelength : {
31            rangelength : [5,10],
32         },
33         notpass : {
34             equalTo : '#pass', //这里的 To 是大写的 T
35         }
36     },
37 })

 

 

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

 1 $('#reg').validate({
 2     rules : {
 3         user : {
 4             required : true,
 5             minlength : 5,
 6             rangelength : [5,10]
 7         },
 8     },
 9     messages : {
10         user : {
11             required : '帐号不得为空!',
12             minlength : jQuery.format('帐号不得小于{0}位!'),
13             rangelength : jQuery.format('帐号限制在{0}-{1}位!'),
14         },
15     },
16 });

 


//开启调试模式禁止提交
$('#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'
},


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

1 errorPlacement : function (error, element) {
2   error.appendTo('.myerror');
3 },

 


//设置错误提示的 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()
  })
},

 

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

 


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

 1 //获取错误提示句柄,不用提交及时获取值
 2 showErrors : function (errorMap, errorList) {
 3     var errors = this.numberOfInvalids();
 4     if (errors) {
 5         $('.myerror').html('您有' + errors + '个表单元素填写非法!');
 6     } else {
 7         $('.myerror').hide();
 8     }
 9     this.defaultShowErrors();   //执行默认错误
10 },
11 
12 
13 //获取错误提示句柄,errorList
14 showErrors : function (errorMap, errorList) {
15     alert(errorList[0].message);   //得到错误信息
16     alert(errorList[0].element);   //当前错误的表单元素
17 },

 

 

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

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

 


//user.php 内容

1 <?php
2     if ($_GET['user'] == 'alex') {
3         echo 'false';
4     } else {
5         echo 'true';
6     }
7 ?>

 


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

 1 pass : {
 2     required : true,
 3     minlength : 6,
 4     remote : {
 5         url : 'user.php',
 6         type : 'POST',
 7         dataType : 'json',
 8         data : {
 9             user : function () {
10                 return $('#user').val();
11             },
12         },
13     },
14 },

 


//user.php 内容

1 <?php
2     if ($_POST['user'] != 'alex' || $_POST['pass'] != '123456') {
3         echo 'false';
4     } else {
5         echo 'true';
6     }
7 ?>

 

 

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 增加一个表单验证

1 $('#user').rules('add', {
2     required : true,
3     minlength : 2,
4     messages : {
5         required : '帐号不得为空!',
6         minlength : jQuery.format('帐号不得小于{0}位!'),
7     }
8 });

 


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


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

 

 1 //添加自定义验证
 2 $.validator.addMethod('code', function (value, element) {
 3     var tel = /^[0-9]{6}$/;
 4     return this.optional(element) || (tel.test(value));
 5   }, '请正确填写您的邮政编码');
 6 
 7 //调用自定义验证
 8 rules : {
 9     code : {
10         required : true,
11         code : true,
12     }
13 }
14 
15  

 

posted on 2014-08-12 09:23 NET未来之路 阅读(...) 评论(...) 编辑 收藏

转载于:https://www.cnblogs.com/lonelyxmas/p/3906507.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/359631.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

爱思助手更新后无法连接服务器,爱思助手出现无法连接或连接超时的操作教程...

使用爱思助手的用户很多&#xff0c;一些新用户不清楚出现无法连接或连接超时怎样处理&#xff0c;今天小编给大家带来在爱思助手出现无法连接或连接超时的操作教程&#xff0c;希望可以帮到大家。爱思助手出现无法连接或连接超时的操作教程一、数据线和电脑USB接口正常状态请确…

计算机演示题打不开,大神为你演示win7系统计算机上右键管理打不开的还原技巧...

当我们经常使用的电脑工作的时候&#xff0c;时间久了难免会遇到win7系统计算机上右键管理打不开的问题&#xff0c;如今就有用户反映在使用电脑的时候遇到win7系统计算机上右键管理打不开的情况不知怎么解决&#xff0c;针对这个问题小编就整理总结出win7系统计算机上右键管理…

gwt-2.8.2下载_GWT 2 Spring 3 JPA 2 Hibernate 3.5教程– Eclipse和Maven 2展示

gwt-2.8.2下载不久前&#xff0c;我的一个朋友和同事向我飞过&#xff0c;说“世界上只有一半在使用Maven ”。 当我意识到最受欢迎的文章&#xff08;到目前为止&#xff09; GWT 2 Spring 3 JPA 2 Hibernate 3.5 Tutorial提出了一种基于Google的Web Toolkit&#xff08; GWT …

111邮箱服务器设置,如何设置Outlook邮箱帐号

在Outlook的邮箱帐号设置中&#xff0c;将POP3服务器和SMTP服务器设置成邮件服务器IP地址&#xff0c;帐号修改成"原登录帐号#原POP3服务器地址"就可以了。假设你已经有了一个 Internet 邮箱为webmasternetease.com 。netease.com的pop3服务器地址是 pop.netease.com…

apache lucene_Apache Lucene拼写检查器的“您是不是要”功能

apache luceneGoogle的“您是不是要”功能 在上一篇文章中对Lucene进行了介绍之后 &#xff0c;现在是时候提高它并创建一个更复杂的应用程序了。 您肯定最熟悉Google的“您是不是要”功能&#xff08;其他搜索引擎也支持此功能&#xff09;。 这是一个例子&#xff1a; Luce…

获取js里添加的css文件,用JS添加一个css文件

我在这里发现了一些关于我的问题的问题&#xff0c;但我无法使用它。 通过JS点击它们时我会改变的CSS属性&#xff0c;JQuery的用JS添加一个css文件GreenRed/*$(document).ready(function() {$(".osn").mouseover(function() {uploadcss()});});*/$(document).ready(…

__construct()和__initialize()

ThinkPHP中的__initialize()和类的构造函数__construct()网上有很多关于__initialize()的说法和用法&#xff0c;总感觉不对头&#xff0c;所以自己测试了一下。将结果和大家分享。不对请更正。首先&#xff0c;我要说的是1、__initialize()不是php类中的函数&#xff0c;php类…

荣耀6手机常显示无法链接服务器怎么处理,华为手机连接上WiFi上不了网怎么办...

华为手机(Mate7,荣耀6 Plus,荣耀6,P7) 连接上WiFi上不了网怎么办每当小编被遇到这样的问题&#xff0c;小编都会深深的醉一把。这样的问题就应该被消灭在火星上&#xff0c;谁让他来地球的。网络就像一张大网&#xff0c;哪个节点有问题都可能导致WIFI连上无法上网&#xff0c;…

初学之道--MFC

放假了&#xff0c;由于作业需要&#xff0c;我开始学习了一下MFC&#xff0c;一开始不知道如何下手&#xff0c;对MFC消息的运行和管理都一概不知&#xff0c;稀里糊涂的去看windows核心编程教学&#xff0c;才知道什么叫看天书&#xff0c; 然后又下载了vs2010开发指南PDF来看…

三国轶事——巴蜀之危

三国佚事——巴蜀之危 Time Limit: 1000ms Memory limit: 65536K 有疑问&#xff1f;点这里^_^ 题目描述 话说天下大势&#xff0c;分久必合&#xff0c;合久必分。。。却道那魏蜀吴三国鼎力之时&#xff0c;多少英雄豪杰以热血谱写那千古之绝唱。古人诚不我欺&#xff0c;确…

jquery ajax是什么意思,Jquery ajax

题目1&#xff1a; jQuery 中&#xff0c; $(document).ready()是什么意思&#xff1f;当html文档DOM树加载完成&#xff0c;执行ready里的函数。传递处理函数给.ready()方法&#xff0c;能保证DOM准备好后就执行这个函数&#xff0c;因此&#xff0c;这里是进行所有其它事件绑…

jboss 配置上下文路径_JBoss Portal上的“ Hello World” portlet

jboss 配置上下文路径Portlet概述 本教程将向您展示如何创建和部署简单的Portlet。 Portlet是基于Java技术的Web组件&#xff0c;可以处理请求并生成动态内容。 Portlet不是自治实体&#xff0c;但是由Portlet容器管理&#xff0c;Portlet容器为Portlet执行提供了必要的运行时…

创建型-工厂方法模式

1、工厂方法模式意图&#xff1a; 定义一个用于创建对象的接口&#xff0c;让子类决定实例化哪一个类。Factory Method使一个类的实例化延迟到其子类。 工厂方法模式用于为属于同一类别的产品定义对应的具体工厂类&#xff0c;并将具体工厂类开放给用户类来使用。 2、应用场景&…

ajax前台multipartfile,在SpringBoot中使用Ajax方式MultipartFile上传失败

虽然在正常的html和表单方式下上传效果很好&#xff0c;但是切换到ajax却失败了&#xff0c;并且在调试模式下MultipartFile总是Null。code below works fine//html code//java codeRequestMapping(value "/api/upload", consumes "*/*", method Reques…

简单图片浏览器

在设置开关灯的时候出了一点小问题&#xff0c;默认UISwitch为on当用if(sender.on)做判断时&#xff0c;第一次点击无效。后来调试默认为on&#xff0c;当改变状态时sender.on返回的是0&#xff0c;再次点击返回的是1。判断一个UISwitch为off可以用!sender.on 用到加载本地目录…

服务器添加角色显示灰色,添加角色 web服务器 灰色

添加角色 web服务器 灰色 内容精选换一换OneAccess支持通过AD认证用户身份和控制权限。AD全称Active Directory&#xff0c;中文名称活动目录。您可以将AD简单理解成一个数据库&#xff0c;其存储有关网络对象的信息&#xff0c;方便管理员和用户查找所需信息。本文主要介绍One…

Hdu1166单点更新线段树

入门线段树&#xff0c;单点更新。写了几遍&#xff0c;都是学着notonlysuccess写的。 #include <cstdio> #include <cstring> #include <algorithm> #include <climits> #include <string> #include <iostream> #include <map> #in…

jboss4.2.3_JBoss 4.2.x Spring 3 JPA Hibernate教程

jboss4.2.3在花费大量时间在网上搜索之后&#xff0c;尝试找到对几个项目使用Spring&#xff0c;JPA和Hibenate的最有效方法&#xff0c;我们得出了将在下面介绍的配置的结论。 将Spring与JPA和Hibernate集成包括几个步骤&#xff1a; Spring容器的配置 JPA ORM层的配置 Hib…

虚拟服务器关机怎么开,云服务器关机了怎么开启

云服务器关机了怎么开启 内容精选换一换开启防护后&#xff0c;您可以根据需要进行安全配置。包括配置常用登录地、常用登录IP、SSH登录IP白名单&#xff0c;开启恶意程序自动隔离查杀功能。配置常用登录地后&#xff0c;企业主机安全服务将对非常用地登录主机的行为进行告警。…

web文件怎么传到服务器,web文件传到服务器

web文件传到服务器 内容精选换一换工具中所有涉及上传文件功能的&#xff0c;如果需要上传的文件大于1GB或者解压后超过剩余磁盘空间的一半&#xff0c;则需要释放磁盘空间或手动将文件上传至服务器&#xff0c;其他情况可通过Web界面上传功能上传。Web服务端证书&#xff0c;即…