jQuery Validate插件实现表单验证
jQuery Validate 插件为表单提供了强大的验证功能,让客户端表单验证变得更简单,提供了大量的定制选项,满足应用程序各种需求。该插件捆绑了一套有用的验证方法,包括 URL 和电子邮件验证,提供了一个用来编写用户自定义方法的 API。所有的捆绑方法默认使用英语作为错误信息,且已翻译成其他 37 种语言。更重要的是他是由jQuery 团队、 jQuery UI 团队的主要开发人员Jörn Zaefferer 编写和维护的。具体我们可以访问 jQuery Validate 官网,下载最新版的 jQuery Validate 插件。
需要引入以下JS文件
<script type="text/javascript" src="jquery.min.js"></script> <script type="text/javascript" src="jquery.validate.min.js"></script> <script type="text/javascript" src="validate-methods.js"></script> <script type="text/javascript" src="messages_zh.min.js"></script>
validate-methods.js 为扩展的验证规则
messages_zh.js 为验证提示文件
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>表单验证</title> <script type="text/javascript" src="jquery.min.js"></script> <script type="text/javascript" src="jquery.validate.min.js"></script> <script type="text/javascript" src="validate-methods.js"></script> <script type="text/javascript" src="messages_zh.min.js"></script> </head> <body> <form action="" method="" class="" id="demo"> <div class=""> <label>帐号</label> <div> <input name="username" type="text"placeholder="请填写由数字、26个英文字母或者下划线组成的帐号!"> </div> </div> <div> <label>手机号码</label> <div> <input name="tel" type="text"placeholder="请输入手机号码"> </div> </div> <div> <label>邮箱</label> <div> <input name="email" type="email"placeholder="请输入邮箱"> </div> </div> <div> <label>必填字段</label> <div> <input name="bt" type="text"placeholder="这是必填字段"> </div> </div> <div> <label>输入密码</label> <div> <input name="password" type="password"placeholder="请输入密码"> </div> </div> <div> <label>请输入密码</label> <div> <input name="password" type="password"placeholder="请输入密码"> </div> </div> <div> <div> <button type="submit">提交</button> </div> </div> </form> </body> <script type="text/javascript"> $("#demo").validate({ rules:{ username:{ required:true, /默认效验规则/ aount :true, /最短6位数,最长16位数/ minlength:6, maxlength:16 }, tel:{ required:true, /默认效验规则/ number:true }, email:{ required:true, /默认效验规则/ email:true }, bt:{ /默认必填/ required:true, }, password:{ required:true, minlength:6, maxlength:16, /密码验证/ equalTo:"#password" }, }, /错误提示/ messages:{ username:{ /错误显示的提示语/ required:"请填写由数字、26个英文字母或者下划线组成的帐号!", minlength:"帐号最小为6位", maxlength:"帐号最大为16位", }, tel:{ required:"请填写手机号码", }, email:{ required:"请填写邮箱", }, password:{ required:"请填写密码", minlength:"密码最小为6位", maxlength:"密码最大为16位", }, }, }); /创建自定义正则表达式语法/ $.validator.addMethod("aount",function(value,element,params){ var aount = /^\w{3,20}$/; return (aount.test(value)); },"请填写由数字、26个英文字母或者下划线组成的帐号!"); $.validator.addMethod("number",function(value,element,params){ var number = /^(((13[0-9]{1})|(15[0-35-9]{1})|(17[0-9]{1})|(18[0-9]{1}))+\d{8})$/; return (number.test(value)); },"请填写正确的手机号码!"); </script> </html>
浏览器结果
默认校验规则
常用的正则表达式
一、校验数字的表达式
1 数字^[0-9]$
2 n位的数字^\d{n}$
3 至少n位的数字^\d{n,}$
4 m-n位的数字^\d{m,n}$
5 零和非零开头的数字^(0|[1-9][0-9])$
6 非零开头的最多带两位小数的数字^([1-9][0-9])+(.[0-9]{1,2})?$
7 带1-2位小数的正数或负数^(\-)?\d+(\.\d{1,2})?$
8 正数、负数、和小数^(\-|\+)?\d+(\.\d+)?$
9 有两位小数的正实数^[0-9]+(.[0-9]{2})?$
10 有1~3位小数的正实数^[0-9]+(.[0-9]{1,3})?$
11 非零的正整数^[1-9]\d$ 或 ^([1-9][0-9]){1,3}$ 或 ^\+?[1-9][0-9]$
12 非零的负整数^\-[1-9][]0-9"$ 或 ^-[1-9]\d$
13 非负整数^\d+$ 或 ^[1-9]\d|0$
14 非正整数^-[1-9]\d|0$ 或 ^((-\d+)|(0+))$
15 非负浮点数^\d+(\.\d+)?$ 或 ^[1-9]\d\.\d|0\.\d[1-9]\d|0?\.0+|0$
16 非正浮点数^((-\d+(\.\d+)?)|(0+(\.0+)?))$ 或 ^(-([1-9]\d\.\d|0\.\d[1-9]\d))|0?\.0+|0$
17 正浮点数^[1-9]\d\.\d|0\.\d[1-9]\d$ 或 ^(([0-9]+\.[0-9][1-9][0-9])|([0-9][1-9][0-9]\.[0-9]+)|([0-9][1-9][0-9]))$
18 负浮点数^-([1-9]\d\.\d|0\.\d[1-9]\d)$ 或 ^(-(([0-9]+\.[0-9][1-9][0-9])|([0-9][1-9][0-9]\.[0-9]+)|([0-9][1-9][0-9])))$
19 浮点数^(-?\d+)(\.\d+)?$ 或 ^-?([1-9]\d\.\d|0\.\d[1-9]\d|0?\.0+|0)$
二、校验字符的表达式
1 汉字^[\u4e00-\u9fa5]{0,}$
2 英文和数字^[A-Za-z0-9]+$ 或 ^[A-Za-z0-9]{4,40}$
3 长度为3-20的所有字符^.{3,20}$
4 由26个英文字母组成的字符串^[A-Za-z]+$
5 由26个大写英文字母组成的字符串^[A-Z]+$
6 由26个小写英文字母组成的字符串^[a-z]+$
7 由数字和26个英文字母组成的字符串^[A-Za-z0-9]+$
8 由数字、26个英文字母或者下划线组成的字符串^\w+$ 或 ^\w{3,20}$
9 中文、英文、数字包括下划线^[\u4E00-\u9FA5A-Za-z0-9_]+$
10 中文、英文、数字但不包括下划线等符号^[\u4E00-\u9FA5A-Za-z0-9]+$ 或 ^[\u4E00-\u9FA5A-Za-z0-9]{2,20}$
11 可以输入含有^%&',;=?$\"等字符[^%&',;=?$\x22]+
12 禁止输入含有~的字符[^~\x22]+
三、特殊需求表达式
1 Email地址^\w+([-+.]\w+)@\w+([-.]\w+)\.\w+([-.]\w+)$
2 域名[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?
3 InterURL[a-zA-z]+://[^\s] 或 ^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=])?$
4 手机号码^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$
5 电话号码("XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX)^(\(\d{3,4}-)|\d{3.4}-)?\d{7,8}$
6 国内电话号码(0511-4405222、021-87888822)\d{3}-\d{8}|\d{4}-\d{7}
7 身份证号
15或18位身份证^\d{15}|\d{18}$
15位身份证^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$
18位身份证^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{4}$
8 短身份证号码(数字、字母x结尾)^([0-9]){7,18}(x|X)?$ 或 ^\d{8,18}|[0-9x]{8,18}|[0-9X]{8,18}?$
9 帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线)^[a-zA-Z][a-zA-Z0-9_]{4,15}$
10 密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线)^[a-zA-Z]\w{5,17}$
11 强密码(必须包含大小写字母和数字的组合,不能使用特殊字符,长度在8-10之间)^(?=.\d)(?=.[a-z])(?=.[A-Z]).{8,10}$
12 日期格式^\d{4}-\d{1,2}-\d{1,2}
13 一年的12个月(01~09和1~12)^(0?[1-9]|1[0-2])$
14 一个月的31天(01~09和1~31)^((0?[1-9])|((1|2)[0-9])|30|31)$
15 钱的输入格式
16 1.有四种钱的表示形式我们可以接受:"10000.00" 和 "10,000.00", 和没有 "分" 的 "10000" 和 "10,000"^[1-9][0-9]$
17 2.这表示任意一个不以0开头的数字,,这也意味着一个字符"0"不通过,所以我们采用狼蚁网站SEO优化的形式^(0|[1-9][0-9])$
18 3.一个0或者一个不以0开头的数字.我们还可以允许开头有一个负号^(0|-?[1-9][0-9])$
19 4.这表示一个0或者一个可能为负的开头不为0的数字.让用户以0开头好了.把负号的也去掉,因为钱总不能是负的吧.狼蚁网站SEO优化我们要加的是说明可能的小数部分^[0-9]+(.[0-9]+)?$
20 5.必须说明的是,小数点后面至少应该有1位数,所以"10."是不通过的, "10" 和 "10.2" 是通过的^[0-9]+(.[0-9]{2})?$
21 6.这样我们规定小数点后面必须有两位,如果你认为太苛刻了,可以这样^[0-9]+(.[0-9]{1,2})?$
22 7.这样就允许用户只写一位小数.狼蚁网站SEO优化我们该考虑数字中的逗号了,我们可以这样^[0-9]{1,3}(,[0-9]{3})(.[0-9]{1,2})?$
23 8.1到3个数字,后面跟着任意个 逗号+3个数字,逗号成为可选,而不是必须^([0-9]+|[0-9]{1,3}(,[0-9]{3}))(.[0-9]{1,2})?$
24 备注这就是最终结果了,别忘了"+"可以用""替代如果你觉得空字符串也可以接受的话(奇怪,为什么?),别忘了在用函数时去掉去掉那个反斜杠,一般的错误都在这里
25 xml文件^([a-zA-Z]+-?)+[a-zA-Z0-9]+\\.[x|X][m|M][l|L]$
26 中文字符的正则表达式[\u4e00-\u9fa5]
27 双字节字符[^\x00-\xff] (包括汉字在内,可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1))
28 空白行的正则表达式\n\s\r (可以用来删除空白行)
29 HTML标记的正则表达式<(\S?)[^>]>.?</\1>|<.? /> (网上流传的版本太糟糕,上面这个也仅仅能部分,对于复杂的嵌套标记依旧无能为力)
30 首尾空白字符的正则表达式^\s|\s$或(^\s)|(\s$) (可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式)
31 腾讯QQ号[1-9][0-9]{4,} (腾讯QQ号从10000开始)
32 中国邮政编码[1-9]\d{5}(?!\d) (中国邮政编码为6位数字)
33 IP地址\d+\.\d+\.\d+\.\d+ (提取IP地址时有用)
精彩专题分享
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程