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等类型都进行了阐述。
<!DOCTYPEhtml>
<html>
<headlang="en">
<metacharset="UTF-8">
</head>
<body>
<form>
<!--input-->
<div>
姓名:<inputtype="text"name="name"notNull="姓名"class="form-controlnoNull">
</div>
<br>
<!--radio-->
<div>
性别:
男<inputtype="radio"name="sex"value="0"class="noNull"notNull="性别">
女<inputtype="radio"name="sex"value="1">
</div>
<br>
<!--select-->
<div>
年龄:
<selectname="age"class="noNull"notNull="年龄">
<optionvalue="">请选择</option>
<optionvalue="1">1</option>
<optionvalue="2">2</option>
</select>
</div>
<br>
<!--checkbox-->
<div>
兴趣:
打球<inputtype="checkbox"name="hobby"value="1"class="noNull"notNull="兴趣">
唱歌<inputtype="checkbox"name="hobby"value="2">
跳舞<inputtype="checkbox"name="hobby"value="3">
</div>
<br>
<buttontype="button"class="btn-c"onclick="bubmi()">保存</button>
</form>
<scriptsrc="jquery-1.9.1.min.js"></script>
<scripttype="text/javascript">
functionbubmi(){
$(".noNull").each(function(){
varname=$(this).attr("name");
if($(this).val()==""){
alert($(this).attr('notNull')+"不能为空");returnfalse;
}
if($(this).attr("type")=="radio"){
if($("input[name='"+name+"']:checked").size()<1){
alert($(this).attr('notNull')+"不能为空!");
returnfalse;
}
}
if($(this).attr("type")=="checkbox"){
if($('input[name="'+name+'"]:checked').size()<1){
alert($(this).attr('notNull')+"不能为空!");
returnfalse;
}
}
})
}
</script>
</body>
</html>
下面给大家介绍jquery.validate.js验证插件
jquery.validate.js是jquery旗下的一个验证插件,借助jquery的优势,我们可以迅速验证一些常见的输入,并且可以自己扩充自己的验证方法。
举个例子,有这么一个表单:
<formid="signupForm"method="get"action=""> <fieldset> <legend>Validatingacompleteform</legend> <p> <labelfor="firstname">Firstname</label> <inputid="firstname"name="firstname"class="required"/> </p> <p> <labelfor="lastname">Lastname</label> <inputid="lastname"name="lastname"/> </p> <p> <labelfor="username">Username</label> <inputid="username"name="username"/> </p> <p> <labelfor="password">Password</label> <inputid="password"name="password"type="password"/> </p> <p> <labelfor="confirm_password">Confirmpassword</label> <inputid="confirm_password"name="confirm_password"type="password"/> </p> <p> <labelfor="email">Email</label> <inputid="email"name="email"/> </p> <p> <inputclass="submit"type="submit"value="Submit"/> </p> </fieldset> </form>
在这个表单中,有名、姓、用户名、密码、确认密码和email。他们都为非空,并且电子邮件需要是格式正确的地址、确认密码和密码一致。使用jQuery验证最简单的方式是引入jquery.js和jqueryvalidation.js两个js文件。然后分别在input中加入class即:
<inputid="firstname"name="firstname"class="required"/> <inputid="lastname"name="lastname"class="required"/> <inputid="username"name="username"class="required"/> <inputid="password"name="password"type="password"class="required"/> <inputid="confirm_password"name="confirm_password"type="password"class="required"equalTo="#password"/> <inputid="email"name="email"class="requiredemail"/>
以下列出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事件中,加入如下方法:
<script>
$(document).ready(function(){
$("#signupForm").validate();
}
</script>
这样,当form被提交的时候,就会根据input指定的class来进行验证了。如果失败,form的提交就会被阻止。并且,将提示信息显示在input的后面。
不过,这样感觉不好,因为验证规则侵入了我们的html代码。还有一个方式,便是使用“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:"格式有误"
}
}
});
})
如果你还想在错误信息上显示特别的样式(比如字体为红色)即可通过添加:
<styletype="text/css">
#signupFormlabel.error{
padding-left:16px;
margin-left:2px;
color:red;
background:url(img/unchecked.gif)no-repeat0px0px;
}
</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");
}
})
})