最常使用JavaScript的场合就是表单的验证,而jQuery作为一个优秀的JavaScript库,也提供了一个优秀的表单验证插件----Validation。Validation是历史最悠久的jQuery插件之一,经过了全球范围内不同项目的验证,并得到了许多Web开发者的好评。作为一个标准的验证方法库,Validation拥有如下特点:

1.内置验证规则: 拥有必填、数字、Email、URL和信用卡号码等19类内置验证规则

2.自定义验证规则: 可以很方便地自定义验证规则

3.简单强大的验证信息提示: 默认了验证信息提示,并提供自定义覆盖默认的提示信息的功能

4.实时验证: 可能通过keyup或blur事件触发验证,而不仅仅在表单提交的时候验证

validate.js下载地址: http://plugins.jquery.com/project/validate

metadata.js下载地址: http://plugins.jquery.com/project/metadata

使用方法:

1.引入jQuery库和Validation插件

[javascript] view
plain
copyprint?

  1. <script src="scripts/jquery-1.6.4.js" type="text/javascript"></script>
  2. <script src="scripts/jquery.validate.js" type="text/javascript"></script>

2.确定哪个表单需要被验证

[javascript] view
plain
copyprint?

  1. <script type="text/javascript">
  2. ////<![CDATA[
  3. $(document).ready(function(){
  4. $("#commentForm").validate();
  5. });
  6. //]]>
  7. </script>

3.针对不同的字段,进行验证规则编码,设置字段相应的属性

[javascript] view
plain
copyprint?

  1. class="required"   必须填写
  2. class="required email"        必须填写且内容符合Email格式验证
  3. class="url"             符合URL格式验证
  4. minlength="2"      最小长度为2

可验证的规则有19种:

[javascript] view
plain
copyprint?

  1. required:      必选字段
  2. remote:        "请修正该字段",
  3. email:         电子邮件验证
  4. url:           网址验证
  5. date:          日期验证
  6. dateISO:       日期 (ISO)验证
  7. dateDE:
  8. number:        数字验证
  9. numberDE:
  10. digits:        只能输入整数
  11. creditcard:    信用卡号验证
  12. equalTo:       ”请再次输入相同的值“验证
  13. accept:        拥有合法后缀名的字符串验证
  14. maxlength/minlength:    最大/最小长度验证
  15. rangelength:     字符串长度范围验证
  16. range:           数字范围验证
  17. max/min:         最大值/最小值验证

另个一种验证方法(将所有的与验证相关的信息写到class属性中方便管理)

1.引入一个新的jQuery插件---jquery.metadata.js(支持固定格式解析的jQuery插件)

[javascript] view
plain
copyprint?

  1. <script src="scripts/jquery.metadata.js" type="text/javascript"></script>

2.改变调用的验证方法

[javascript] view
plain
copyprint?

  1. <script type="text/javascript">
  2. ////<![CDATA[
  3. $(document).ready(function(){
  4. //将$("#commentForm").validate();  改成
  5. $("#commentForm").validate({meta: "validate"});
  6. });
  7. //]]>
  8. </script>

3.将验证规则全部编写到class属性中

[javascript] view
plain
copyprint?

  1. class="{validate:{required: true, minlength: 2, messages:{required:'请输入姓名', minlength:'请至少输入两个字符'}}}"
  2. class="{validate:{required: true, email: true, messages:{required:'请输入电子邮件', email:'请检查电子邮件的格式'}}}"

也可以通过name属性来关联字段和验证规则的验证写法(验证行为和HTML结构完全脱钩)

[javascript] view
plain
copyprint?

  1. $("#commentForm").validate({
  2. rules: {
  3. username: {
  4. required: true,
  5. minlength: 2
  6. },
  7. email: {
  8. required: true,
  9. email: true
  10. },
  11. url:"url",
  12. comment: "required"
  13. },
  14. messages: {
  15. username: {
  16. required: '请输入姓名',
  17. minlength: '请至少输入两个字符'
  18. },
  19. email: {
  20. required: '请输入电子邮件',
  21. email: '请检查电子邮件的格式'
  22. },
  23. url: '请检查网址的格式',
  24. comment: '请输入您的评论'
  25. }
  26. });

国际化

Validation插件的验证信息默认语言是英文,如果要改成中文,只需要引入Validation提供的中文验证信息即可,引入代码如下:

[javascript] view
plain
copyprint?

  1. <script src="scripts/jquery.validate.messages_cn.js" type="text/javascript"></script>

自定义验证信息并美化

[javascript] view
plain
copyprint?

  1. errorElement: "em",               //可以用其他标签,记住把样式也对应修改
  2. success: function(label) {    //label指向上面那个错误提示信息标签em
  3. label.text("")                       //清空错误提示消息
  4. .addClass("success");    //加上自定义的success类
  5. }
  6. 在CSS中添加样式与之关联
  7. em.error {
  8. background:url("images/unchecked.gif") no-repeat 0px 0px;
  9. padding-left: 16px;
  10. }
  11. em.success {
  12. background:url("images/checked.gif") no-repeat 0px 0px;
  13. padding-left: 16px;
  14. }

自定义验证规则

[javascript] view
plain
copyprint?

  1. //自定义一个验证方法
  2. $.validator.addMethod(
  3. "formula", //验证方法名称
  4. function(value, element, param) {//验证规则
  5. return value == eval(param);
  6. },
  7. '请正确输入数学公式计算后的结果'//验证提示信息
  8. );
  9. $("#commentForm").validate({
  10. rules: {
  11. username: {
  12. required: true,
  13. minlength: 2
  14. },
  15. email: {
  16. required: true,
  17. email: true
  18. },
  19. url:"url",
  20. comment: "required",
  21. valcode: {
  22. formula: "7+9"
  23. }
  24. },
  25. messages: {
  26. username: {
  27. required: '请输入姓名',
  28. minlength: '请至少输入两个字符'
  29. },
  30. email: {
  31. required: '请输入电子邮件',
  32. email: '请检查电子邮件的格式'
  33. },
  34. url: '请检查网址的格式',
  35. comment: '请输入您的评论',
  36. valcode: '验证码错误'
  37. }
  38. });

表单验证插件jquery.validate.js的更多相关文章

  1. jQuery插件 -- 表单验证插件jquery.validate.js, jquery.metadata.js

    原文地址:http://blog.csdn.net/zzq58157383/article/details/7718352   最常使用JavaScript的场合就是表单的验证,而jQuery作为一个 ...

  2. jQuery插件 -- 表单验证插件jquery.validate.js

    最常使用JavaScript的场合就是表单的验证,而jQuery作为一个优秀的JavaScript库,也提供了一个优秀的表单验证插件----Validation.Validation是历史最悠久的jQ ...

  3. jQuery表单验证插件——jquery.validate.js

    官网地址:http://bassistance.de/jquery-plugins/jquery-plugin-validation 一.导入js库 <script src="../j ...

  4. 表单验证插件jquery.validate的使用方法演示

    jQueryValidate表单验证效果 jquery.validate验证错误信息的样式控制 <!--validate验证插件的基础样式--> input.error{border: 1 ...

  5. jq中的表单验证插件------jquery.validate

    今天我们来说一下表单验证,有人说我们在进行表单验证的时候使用正则来验证是非常麻烦的,现在我来给大家介绍一下表单验证的插件:jquery.validate.min.js 它是与jquery一起结合用来使 ...

  6. jquery表单验证插件 jquery.form.js ------转载

    Form插件,支持Ajax,支持Ajax文件上传,功能强大,基本满足日常应用. 1.JQuery框架软件包下载 文件: jquery.rar 大小: 29KB 下载: 下载 2.Form插件下载 文件 ...

  7. jQuery 表单验证插件 jQuery Validation Engine 使用

    jQuery 表单验证插件 jQuery Validation Engine 使用方式如下: 1.引入头文件(注意一定要把jQuery放在前面),指定使用 jQuery Validation Engi ...

  8. 表单验证神器——jquery.validate插件

    jquery.validate.js插件应用举例,ajax方式提交数据. html代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Tr ...

  9. 表单验证插件 jquery.validata 使用方法

    参考资料:http://www.runoob.com/jquery/jquery-plugin-validate.html 下载地址 jquery.validate插件的文档地址http://docs ...

随机推荐

  1. ACM学习历程—HDU 5317 RGCDQ (数论)

    Problem Description Mr. Hdu is interested in Greatest Common Divisor (GCD). He wants to find more an ...

  2. CF 908D New Year and Arbitrary Arrangement——期望dp

    题目:http://codeforces.com/contest/908/problem/D 注意是子序列.加一个a对ab个数无影响:加一个b使ab个数多出它前面的a那么多个.所以状态里记录有多少个a ...

  3. 洛谷 P5061 秘密任务 —— 二分图

    题目:https://www.luogu.org/problemnew/show/P5061 首先,“配合默契”就是连边的意思: 但发现答案不好统计,因为有连边的两个点可以分在一组,也可以不分在一组: ...

  4. C++ 创建文件的方法

    CString getPath(){ CTime time = CTime::GetCurrentTime(); CString t = time.Format(_T("%Y%m%d%H%M ...

  5. WPF DatePicker 的textbox的焦点

    要得到DatePicker的textchange属性, 必须通过TextBoxBase.TextChanged 事件来处理. 想要判断是否当前DatePicker的textbox获取到焦点, 可以通过 ...

  6. LWIP的底层结构(物理层)

    LWIP的底层结构(物理层) 转自:http://bluefish.blog.51cto.com/214870/158418 我们前面讲到说是ip层的发送和接收都是直接调用了底层,也就是设备驱动层的函 ...

  7. 0003_Linux基础之常用命令

    1.pwd:查看当前所在目录 2.cd :切换目录 3.ls:查看当前目录下的文件及文件夹: 4.ls -l :列出当前目录下文件及详细信息         drwxr-xr-x   第一个字符为d则 ...

  8. MSSQl分布式查询(转)

    MSSQlServer所谓的分布式查询(Distributed Query)是能够访问存放在同一部计算机或不同计算机上的SQL Server或不同种类的数据源, 从概念上来说分布式查询与普通查询区别 ...

  9. 条款32:确定你的public继承塑模出is-a的关系

    Make sure public inheritance models "is –a " 如果令clsss D 以public的形式继承class B,你便是告诉编译器说,每一个类 ...

  10. Android下如何计算要显示的字符串所占的宽度和高度

    Rect bounds = new Rect(); String text = "Hello World"; TextPaint paint; paint = findViewBy ...