微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

jquery 表单验证之通过 class验证表单不为空

在开发系统时,往往都有某些表单数据为必填项,若用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等类型都进行了阐述。

rush:js;"> Meta charset="UTF-8">
姓名:
性别: 男dio" name="sex" value="0" class="noNull" notNull="性别"> 女

年龄:

兴趣: 打球Box" name="hobby" value="1" class="noNull" notNull="兴趣"> 唱歌Box" name="hobby" value="2"> 跳舞Box" name="hobby" value="3">

下面给大家介绍jquery.validate.js验证插件

jquery.validate.js是jquery旗下的一个验证插件,借助jquery的优势,我们可以迅速验证一些常见的输入,并且可以自己扩充自己的验证方法

举个例子,有这么一个表单:

rush:js;">
Validating a complete form

irstname" name="firstname" class="required"/>

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

rush:js;"> irstname" name="firstname" class="required"/> required"/> required"/> required"/> required" equalTo="#password"/> 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的read事件中,加入如下方法

rush:js;">

这样,当form被提交的时候,就会根据input指定的class来进行验证了。如果失败,form的提交就会被阻止。并且,将提示信息显示在input的后面。

不过,这样感觉不好,因为验证规则侵入了我们的HTML代码。还有一个方式,便是使用“rules”。我们将input的那些验证用class删除掉。然后修改document的ready事件响应代码

rush:js;"> $(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 } } }); })

这样以来,也能达到相同的效果

那么,接下的问题,就是显示错误提示认的。我们需要使用自定义提示

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

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

rush:js;">