JQuery笔记(表单验证)
来源:互联网 发布:window.opener js方法 编辑:程序博客网 时间:2024/06/18 07:55
jquery.validate.js是jquery旗下的一个验证插件,借助jquery的优势,我们可以迅速验证一些常见的输入,并且可以自己扩充自己的验证方法。
举个例子,有这么一个表单:
在这个表单中,有名、姓、用户名、密码、确认密码和email。他们都为非空,并且电子邮件需要是格式正确的地址、确认密码和密码一致。使用jQuery验证最简单的方式是引入jquery.js和jquery validation.js两个js文件。然后分别在input中加入class即:
以下列出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:"格式有误"
}
}
});
})
如果你还想在错误信息上显示特别的样式(比如字体为红色)即可通过添加:
<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");
}
})
})
- JQuery笔记(表单验证)
- JQuery笔记(表单验证) 二
- JQuery笔记(表单验证) 三
- JQuery笔记(表单验证)四 errorcontainer-demo_2.html
- JQuery笔记(表单验证)六 errorcontainer-demo_4.html errorClass
- JQuery笔记(表单验证)七 errorcontainer-demo_5.html errorElement
- jquery.validate 学习笔记(验证form表单工具)
- jQuery学习笔记5 表单验证
- jQuery学习笔记-Validation表单验证插件
- jQuery学习笔记——表单验证
- jQuery 插件 jQuery Validation (表单验证)
- JQuery笔记(表单验证)八 metadata-demo.html jquery.metadata.js
- JQuery EasyUI表单-表单验证
- jQuery表单验证(含ajax)
- JQuery FormValidator表单验证(转)
- jquery 表单验证插件
- JQuery验证表单例子
- jQuery对表单验证
- MYSQL 删除同一表中重复记录
- Cooper:面向UI的敏捷开发(四)
- mysql 用同一表中的另一行记录的字段赋值
- Cooper:面向UI的敏捷开发(五)
- asp.net身份验证探索
- JQuery笔记(表单验证)
- 批量跳过mysql slave错误小脚本
- customerrors 配置节的使用
- eval数据绑定函数解析
- Amarok play music and internet radio
- I Miss You
- Command对象
- JAVA中int转String类型效率比较
- IBM微软工资策略有何不同 七要素决定薪水