jquery 表单验证 jquery.validate.js验证插件

来源:互联网 发布:梦幻妖子 知乎 编辑:程序博客网 时间:2024/05/21 17:19

在开发系统时,往往都有某些表单数据为必填项,若用jQuery通过ID去验证,不仅会影响效率,还会有所遗漏,不易于后期维护。
本章将介绍如何利用jQuery,通过为表单配置class进行统一验证。(ID一个页面只可以使用一次;class可以多次引用)
1:为input添加class,名字可以随意设置,但每个input需要保持一致,本章案例calss设置为noNull。(若input已有class属性,可直接加到其后)
2:为input添加一个属性,用来后期通过jquery获取该字段,用作提示语。本章案例提示属性为notNull。
3:通过jQuery遍历页面中所有calss为noNull的表单,验证其是否为空,若为空,通过获取notNull的字段,进行为空提示。
具体如何设置,请参照下面的案例。
本章针对input,radio,select,checkbox等类型都进行了阐述。

<!DOCTYPE html><html><head lang="en">  <meta charset="UTF-8"></head><body>  <form>      <!-- input -->      <div>        姓名: <input type="text" name="name" notNull="姓名" class="form-control noNull">       </div>      <br>      <!-- radio -->      <div>       性别:       男<input type="radio" name="sex" value="0" class="noNull" notNull="性别"><input type="radio" name="sex" value="1" >      </div>      <br>      <!-- select -->      <div>        年龄:        <select name="age" class="noNull" notNull="年龄">          <option value ="">请选择</option>          <option value ="1">1</option>          <option value ="2">2</option>        </select>      </div>      <br>      <!-- checkbox -->      <div>        兴趣:        打球<input type="checkbox" name="hobby" value="1" class="noNull" notNull="兴趣">        唱歌<input type="checkbox" name="hobby" value="2">        跳舞<input type="checkbox" name="hobby" value="3">      </div>      <br>     <button type="button" class="btn-c" onclick="bubmi()">保存</button>  </form><script src="jquery-1.9.1.min.js"></script><script type="text/javascript">function bubmi(){  $(".noNull").each(function(){    var name = $(this).attr("name");    if($(this).val()==""){    alert($(this).attr('notNull')+"不能为空");return false;    }    if($(this).attr("type")=="radio"){       if ($("input[name='"+name+"']:checked").size() < 1){         alert($(this).attr('notNull')+"不能为空!");         return false;       }     }    if($(this).attr("type")=="checkbox"){       if ($('input[name="'+name+'"]:checked').size() < 1){         alert($(this).attr('notNull')+"不能为空!");         return false;       }     }      })  }</script></body></html>

下面给大家介绍jquery.validate.js验证插件
jquery.validate.js是jquery旗下的一个验证插件,借助jquery的优势,我们可以迅速验证一些常见的输入,并且可以自己扩充自己的验证方法。
举个例子,有这么一个表单:

<form id="signupForm" method="get" action=""><fieldset><legend>Validating a complete form</legend><p><label for="firstname">Firstname</label><input id="firstname" name="firstname" class="required"/></p><p><label for="lastname">Lastname</label><input id="lastname" name="lastname" /></p><p><label for="username">Username</label><input id="username" name="username" /></p><p><label for="password">Password</label><input id="password" name="password" type="password" /></p><p><label for="confirm_password">Confirm password</label><input id="confirm_password" name="confirm_password" type="password" /></p><p><label for="email">Email</label><input id="email" name="email" /></p><p><input class="submit" type="submit" value="Submit"/></p></fieldset></form>

在这个表单中,有名、姓、用户名、密码、确认密码和email。他们都为非空,并且电子邮件需要是格式正确的地址、确认密码和密码一致。使用jQuery验证最简单的方式是引入jquery.js和jquery validation.js两个js文件。然后分别在input中加入class即:

<input id="firstname" name="firstname" class="required"/><input id="lastname" name="lastname" class="required"/><input id="username" name="username" class="required"/><input id="password" name="password" type="password" class="required"/><input id="confirm_password" name="confirm_password" type="password" class="required"   equalTo="#password"/><input id="email" name="email" class="required email"/>

以下列出validate自带的默认验证
required: “必选字段”,
remote: “请修正该字段”,
email: “请输入正确格式的电子邮件”,
url: “请输入合法的网址”,
date: “请输入合法的日期”,
dateISO: “请输入合法的日期 (ISO).”,
number: “请输入合法的数字”,
digits: “只能输入整数”,
creditcard: “请输入合法的信用卡号”,
equalTo: “请再次输入相同的值”,
accept: “请输入拥有合法后缀名的字符串”,
maxlength: jQuery.format(“请输入一个长度最多是 {0} 的字符串”),
minlength: jQuery.format(“请输入一个长度最少是 {0} 的字符串”),
rangelength: jQuery.format(“请输入一个长度介于 {0} 和 {1} 之间的字符串”),
range: jQuery.format(“请输入一个介于 {0} 和 {1} 之间的值”),
max: jQuery.format(“请输入一个最大为 {0} 的值”),
min: jQuery.format(“请输入一个最小为 {0} 的值”)

然后,在document的ready事件中,加入如下方法:

<script> $(document).ready(function(){     $("#signupForm").validate(); }</script>

这样,当form被提交的时候,就会根据input指定的class来进行验证了。如果失败,form的提交就会被阻止。并且,将提示信息显示在input的后面。
还有一个方式,便是使用“rules”。我们将input的那些验证用class删除掉。然后修改document的ready事件响应代码:

$(document).ready(function(){    $("#signupForm").validate({        rules:{            firstname:"required",            lastname:"required",            username:"required",            password:"required",            confirm_password:{                required:true,                equalTo:"#password"            },            email:{                required:true,                email:true            }        }    });})

这样一来,也能达到相同的效果。
那么,接下的问题,就是显示的错误提示是默认的。我们需要使用自定义的提示:

$(document).ready(function(){    $("#signupForm").validate({        rules:{            firstname:"required",            lastname:"required",            username:"required",            password:"required",            confirm_password:{                required:true,                equalTo:"#password"            },            email:{                required:true,                email:true            }        },        messages:{            firstname:"必填项",            lastname:"必填项",            username:"必填项",            password:"必填项",            confirm_password:{                required:"必填项",                equalTo:"密码不一致"            },            email:{                required:"必填项",                email:"格式有误"            }        }    });})

如果你还想在错误信息上显示特别的样式(比如字体为红色)即可通过添加:

<style type="text/css">#signupForm label.error {padding-left: 16px;margin-left: 2px;color:red;background: url(img/unchecked.gif) no-repeat 0px 0px;}</style>

继续添加对输入密码长度的验证规则:

$(document).ready(function(){    $("#signupForm").validate({        rules:{            firstname:"required",            lastname:"required",            username:"required",            password:{                required:true,                minlength:4,                maxlength:15            },            confirm_password:{                required:true,                equalTo:"#password"            },            email:{                required:true,                email:true            }        },        messages:{            firstname:"必填项",            lastname:"必填项",            username:"必填项",            password:{                required:"必填项",                minlength:jQuery.format("密码长度不少于{0}位"),                maxlength:jQuery.format("密码长度不超过{0}位")            },            confirm_password:{                required:"必填项",                equalTo:"密码不一致"            },            email:{                required:"必填项",                email:"格式有误"            }        }    });})

使用remote
可以通过event指定触发效验方式(可选值有keyup(每次按键时),blur(当控件失去焦点时),不指定时就只在按提交按钮时触发)

$(document).ready(function(){    $("#signupForm").validate({        event:"keyup" || "blur"    })})

如果通过指定debug为true则表单不会提交只能用来验证(默认为提交),可用来调试

$(document).ready(function(){    $("#signupForm").validate({        debug:true    })})

如果在提交前还需要进行一些自定义处理使用submitHandler参数

$(document).ready(function(){    $("#signupForm").validate({        SubmitHandler:function(){            alert("success");        }    })})
0 0