验证操作类formValidatorClass.js
1data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt="" /**//**
2 * @author ming
3 */
4data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt="" $(document).ready(function() {
5
6data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" /**//* 设置默认属性 */
7data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" $.validator.setDefaults( {
8data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" submitHandler: function(form) {
9 form.submit();
10 }
11 });
12
13 // 字符验证
14data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" jQuery.validator.addMethod("stringCheck", function(value, element) {
15 return this.optional(element) || /^[\u0391-\uFFE5\w]+$/.test(value);
16 }, "只能包括中文字、英文字母、数字和下划线");
17
18 // 中文字两个字节
19data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" jQuery.validator.addMethod("byteRangeLength", function(value, element, param) {
20 var length = value.length;
21data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" for(var i = 0; i < value.length; i++) {
22data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" if(value.charCodeAt(i) > 127) {
23 length++;
24 }
25 }
26 return this.optional(element) || ( length >= param[0] && length <= param[1] );
27 }, "请确保输入的值在3-15个字节之间(一个中文字算2个字节)");
28
29 // 身份证号码验证
30data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" jQuery.validator.addMethod("isIdCardNo", function(value, element) {
31 return this.optional(element) || isIdCardNo(value);
32 }, "请正确输入您的身份证号码");
33
34 // 手机号码验证
35data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" jQuery.validator.addMethod("isMobile", function(value, element) {
36 var length = value.length;
37 var mobile = /^(((13[0-9]{1})|(15[0-9]{1}))+\d{8})$/;
38 return this.optional(element) || (length == 11 && mobile.test(value));
39 }, "请正确填写您的手机号码");
40
41 // 电话号码验证
42data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" jQuery.validator.addMethod("isTel", function(value, element) {
43 var tel = /^\d{3,4}-?\d{7,9}$/; //电话号码格式010-12345678
44 return this.optional(element) || (tel.test(value));
45 }, "请正确填写您的电话号码");
46
47 // 联系电话(手机/电话皆可)验证
48data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" jQuery.validator.addMethod("isPhone", function(value,element) {
49 var length = value.length;
50 var mobile = /^(((13[0-9]{1})|(15[0-9]{1}))+\d{8})$/;
51 var tel = /^\d{3,4}-?\d{7,9}$/;
52 return this.optional(element) || (tel.test(value) || mobile.test(value));
53
54 }, "请正确填写您的联系电话");
55
56 // 邮政编码验证
57data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" jQuery.validator.addMethod("isZipCode", function(value, element) {
58 var tel = /^[0-9]{6}$/;
59 return this.optional(element) || (tel.test(value));
60 }, "请正确填写您的邮政编码");
61
62 //开始验证
63data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" $('#submitForm').validate( {
64data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" /**//* 设置验证规则 */
65data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" rules: {
66data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" username: {
67 required:true,
68 stringCheck:true,
69 byteRangeLength:[3,15]
70 },
71data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" email: {
72 required:true,
73 email:true
74 },
75data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" phone: {
76 required:true,
77 isPhone:true
78 },
79data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" address: {
80 required:true,
81 stringCheck:true,
82 byteRangeLength:[3,100]
83 }
84 },
85
86data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" /**//* 设置错误信息 */
87data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" messages: {
88data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" username: {
89 required: "请填写用户名",
90 stringCheck: "用户名只能包括中文字、英文字母、数字和下划线",
91 byteRangeLength: "用户名必须在3-15个字符之间(一个中文字算2个字符)"
92 },
93data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" email: {
94 required: "请输入一个Email地址",
95 email: "请输入一个有效的Email地址"
96 },
97data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" phone: {
98 required: "请输入您的联系电话",
99 isPhone: "请输入一个有效的联系电话"
100 },
101data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" address: {
102 required: "请输入您的联系地址",
103 stringCheck: "请正确输入您的联系地址",
104 byteRangeLength: "请详实您的联系地址以便于我们联系您"
105 }
106 },
107
108data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" /**//* 设置验证触发事件 */
109 focusInvalid: false,
110 onkeyup: false,
111
112data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" /**//* 设置错误信息提示DOM */
113data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" errorPlacement: function(error, element) {
114 error.appendTo( element.parent());
115 },
116
117 });
118
119 });
测试页index.html
1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
2 "http://www.w3.org/TR/html4/loose.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml">
4 <head>
5 <meta http-equiv="Content-Type" content="text/html; charset=gbk" />
6 <title>jQuery验证</title>
7 <script src="lib/jquery/jquery-1.3.2.min.js" ></script>
8 <script type="text/javascript" src="lib/jquery/jquery.validate.js" mce_src="lib/jquery/jquery.validate.js"></script>
9 <script type="text/javascript" src="lib/jquery/messages_cn.js"></script>
10 <script type="text/javascript" src="lib/jquery/formValidatorClass.js"></script>
11data:image/s3,"s3://crabby-images/74344/7434462ea806eb136e024cab9042709a0094c067" alt="" <style type="text/css">data:image/s3,"s3://crabby-images/6d069/6d06982ffc7ca95730afc6256bc80fadfbe91a13" alt=""
12data:image/s3,"s3://crabby-images/e596d/e596d84e0d3156e8284ca24e9be2f14439dc5095" alt=""
13data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" * { }{
14 font-family: Verdana;
15 font-size: 96%;
16 }
17data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" label { }{
18 width: 10em;
19 float: left;
20 }
21data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" label.error { }{
22 float: none;
23 color: red;
24 padding-left: .5em;
25 vertical-align: top;
26 }
27data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" p { }{
28 clear: both;
29 }
30data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" .submit { }{
31 margin-left: 12em;
32 }
33data:image/s3,"s3://crabby-images/28bef/28bef155cb11180b5b83e39116777916230caf6e" alt="" em { }{
34 font-weight: bold;
35 padding-right: 1em;
36 vertical-align: top;
37 }
38
39 </style>
40 </head>
41 <body>
42 <form class="submitForm" id="submitForm" method="get" action="">
43 <fieldset>
44 <legend>表单验证</legend>
45 <p>
46 <label for="username">用户名</label>
47 <em>*</em><input id="userName" name="username" size="25" />
48 </p>
49 <p>
50 <label for="email">E-Mail</label>
51 <em>*</em><input id="email" name="email" size="25" />
52 </p>
53 <p>
54 <label for="phone">联系电话</label>
55 <em>*</em><input id="phone" name="phone" size="25" value="" />
56 </p>
57 <p>
58 <label for="address">地址</label>
59 <em>*</em><input id="address" name="address" size="22">
60 </p>
61 <input class="submit" type="submit" value="提交"/>
62 </p>
63 </fieldset>
64 </form>
65 </body>
66 </html>
|