jQuery Validate初步体验(一)
jQuery是一个快速、简单的JavaScriptlibrary,它简化了HTML文件的traversing,事件处理、动画、Ajax互动,从而方便了网页制作的快速发展。jQuery是为改变你编写JavaScript的方式而设计的。
jQueryValidate插件为表单提供了强大的验证功能,让客户端表单验证变得更简单。
但是在学习的过程中,我也遇到了疑惑,网上的很多例子貌似都是依赖jquery.metadata.js这个库,然后在标签里写成class=”requiredremote”这样的形式,class本身是呈现样式的,现在被附上各种校验的规则,看上去有些乱。那如果不依赖jquery.metadata.js,又该怎么写。
1、只引入jquery.js(具体版本自己选择)和jquery.validate.js
<!DOCTYPEhtml> <html> <head> <scriptsrc="js/jquery.js"></script> <scriptsrc="js/jquery.validate.js"></script> <script> $().ready(function(){ $("#registerForm").validate(); }); </script> </head> <body> <formid="registerForm"method="get"action=""> <fieldset> <p> <labelfor="cusername">用户名</label> <inputid="cusername"name="username"type="text"required="true"rangelength="[2,10]"> </p> <p> <labelfor="cpassword">密码</label> <inputid="cpassword"name="password"type="password"required="true"minlength="6"> </p> <p> <labelfor="cconfirmpassword">确认密码</label> <inputid="cconfirmpassword"name="confirmpassword"type="password"required="true"equalTo="#cpassword"> </p> <p> <labelfor="cemail">邮箱</label> <inputid="cemail"name="email"required="true"email="true"></input> </p> <p> <inputtype="submit"value="提交"> </p> </fieldset> </form> </body> </html>
事实证明,只引入上面的两个JS文件也能完成简单的表单验证。
2、不过由于默认的提示信息是英文的,为了能有一个友好的提示,所以,接下来要做的就是让提示信息显示成中文了。
方法一、通过javascript自定义提示信息。
<!DOCTYPEhtml> <html> <head> <scriptsrc="js/jquery.js"></script> <scriptsrc="js/jquery.validate.js"></script> <script> $().ready(function(){ $("#registerForm").validate({ rules:{ username:{ required:true, rangelength:[2,10] }, password:{ required:true, minlength:6 }, confirmpassword:{ required:true, equalTo:"#cpassword" }, email:{ required:true, email:true } }, messages:{ username:{ required:'请输入姓名', rangelength:'长度在{0}到{1}之间' }, password:{ required:'请输入密码', minlength:'密码不能少于{0}位' }, confirmpassword:{ required:'请再次输入密码', equalTo:'两次输入的密码不一致' }, email:{ required:'请输入邮箱', email:'请输入有效的电子邮件地址' } } }); }); </script> </head> <body> <formid="registerForm"method="get"action=""> <fieldset> <p> <labelfor="cusername">用户名</label> <inputid="cusername"name="username"type="text"/> </p> <p> <labelfor="cpassword">密码</label> <inputid="cpassword"name="password"type="password"/> </p> <p> <labelfor="cconfirmpassword">确认密码</label> <inputid="cconfirmpassword"name="confirmpassword"type="password"/> </p> <p> <labelfor="cemail">邮箱</label> <inputid="cemail"name="email"type="email"/> </p> <p> <inputtype="submit"value="提交"> </p> </fieldset> </form> </body> </html>
首先这里有一个方法调用:$("#registerForm").validate([options]),这是用来验证选择的表单,方法的参数是可选项,可以输入0个或者多个键值对(key/value),这个方法是为了处理例如:submit,focus, keyup,blur,click触发验证的,对象是整个表单的元素,或者是单个元素,使用rules和messages定义验证的元素,使用errorClass,errorElement,wrapper,errorLabelContainer,errorContainer,showErrors,success,errorPlacement,highlight,unhighlight,ignoreTitle去控制非法元素的错误信息显示。其中rules里也可以输入0个或者多个键值对,他的key对应的是元素的name属性值,例如username,confirmpassword等等。而他的value里则是一些验证规则。messages同rules一样可以输入0个或者多个键值对,他的key也是对应的元素的name属性值,而他的value里则是验证错误的提示信息。简而言之,rules{}中定义验证规则的方法。messages{}中定义错误输出。
上面有一点需要注意的就是 equalTo:"#cpassword",这个键值对里的value是元素的ID值(如果注意到#号就应该能察觉到)。
通过上面的写法,你就可以自定义提示信息了。或许你会有疑问了,难道我每次验证表单的时候都要重新自定义提示信息吗?当然不是了,你还可以CtrlC+CtrlV。这当然是玩笑话。。。不过,接下来的方法二会解决你的疑问。
方法二、自定义一份提示信息,然后保存成JS文件。把他作为模板,然后在需要的页面直接引入就行。我是从网上下载了一份。
(function(factory){ if(typeofdefine==="function"&&define.amd){ define(["jquery","../jquery.validate"],factory); }else{ factory(jQuery); } }(function($){ /* *TranslateddefaultmessagesforthejQueryvalidationplugin. *Locale:ZH(Chinese,中文(Zhōngwén),汉语,漢語) */ $.extend($.validator.messages,{ required:"这是必填字段", remote:"请修正此字段", email:"请输入有效的电子邮件地址", url:"请输入有效的网址", date:"请输入有效的日期", dateISO:"请输入有效的日期(YYYY-MM-DD)", number:"请输入有效的数字", digits:"只能输入数字", creditcard:"请输入有效的信用卡号码", equalTo:"你的输入不相同", extension:"请输入有效的后缀", maxlength:$.validator.format("最多可以输入{0}个字符"), minlength:$.validator.format("最少要输入{0}个字符"), rangelength:$.validator.format("请输入长度在{0}到{1}之间的字符串"), range:$.validator.format("请输入范围在{0}到{1}之间的数值"), max:$.validator.format("请输入不大于{0}的数值"), min:$.validator.format("请输入不小于{0}的数值") }); }));
页面的代码和JV1.HTML几乎是一模一样,只是多引入了一份JS文件。
<!DOCTYPEhtml> <html> <head> <scriptsrc="js/jquery.js"></script> <scriptsrc="js/jquery.validate.js"></script> <scriptsrc="js/messages_zh.js"></script> <script> $().ready(function(){ $("#registerForm").validate(); }); </script> </head> <body> <formid="registerForm"method="get"action=""> <fieldset> <p> <labelfor="cusername">用户名</label> <inputid="cusername"name="username"type="text"required="true"rangelength="[2,10]"> </p> <p> <labelfor="cpassword">密码</label> <inputid="cpassword"name="password"type="password"required="true"minlength="6"> </p> <p> <labelfor="cconfirmpassword">确认密码</label> <inputid="cconfirmpassword"name="confirmpassword"type="password"required="true"equalTo="#cpassword"> </p> <p> <labelfor="cemail">邮箱</label> <inputid="cemail"name="email"required="true"email="true"></input> </p> <p> <inputtype="submit"value="提交"> </p> </fieldset> </form> </body> </html>
方法一和方法二并不互斥,两种方法是可以结合使用的。你可以先用方法二保存一份比较通用的模板,然后再用方法一去按具体情况来自定义提示。
以上就是我今天下午学习的收获了。据说在新版本中,又有了新的写法,既不需要依赖上面提到的jquery.metadata.js库,也不需要通过javascript自定义提示信息,而是在标签里以data-rule-验证规则、data-msg-提示信息这样的格式来重新定义。跃跃欲试......
下面是官网提供的默认校验规则。
(1)required:true必输字段
(2)remote:"check.php"使用ajax方法调用check.php验证输入值
(3)email:true必须输入正确格式的电子邮件
(4)url:true必须输入正确格式的网址
(5)date:true必须输入正确格式的日期
(6)dateISO:true必须输入正确格式的日期(ISO),例如:2009-06-23,1998/01/22只验证格式,不验证有效性
(7)number:true必须输入合法的数字(负数,小数)
(8)digits:true必须输入整数
(9)creditcard:必须输入合法的信用卡号
(10)equalTo:"#field"输入值必须和#field相同
(11)accept:输入拥有合法后缀名的字符串(上传文件的后缀)
(12)maxlength:5输入长度最多是5的字符串(汉字算一个字符)
(13)minlength:10输入长度最小是10的字符串(汉字算一个字符)
(14)rangelength:[5,10]输入长度必须介于5和10之间的字符串")(汉字算一个字符)
(15)range:[5,10]输入值必须介于5和10之间
(16)max:5输入值不能大于5
(17)min:10输入值不能小于10
好了,摸索了近两个小时,我的第一篇随笔到这也算是完成了。同时希望能给大家带来灵感。
下篇文章给大家介绍jQueryValidate初步体验(二),一起学习吧。