码迷,mamicode.com
首页 > Web开发 > 详细

C - jQuery Validate初体验(一)

时间:2015-12-09 23:12:36      阅读:285      评论:0      收藏:0      [点我收藏+]

标签:

jQuery Validate 插件为表单提供了强大的验证功能,让客户端表单验证变得更简单。

但是在学习的过程中,我也遇到了疑惑,网上的很多例子貌似都是依赖jquery.metadata.js这个库,然后在标签里写成class=”required remote” 这样的形式,class本身是呈现样式的,现在被附上各种校验的规则,看上去有些乱。那如果不依赖jquery.metadata.js,又该怎么写。

1、只引入jquery.js(具体版本自己选择)和jquery.validate.js

技术分享
<!DOCTYPE html>
<html>
<head>
<script src="js/jquery.js"></script>
<script src="js/jquery.validate.js"></script>
<script>
    $().ready(function() {
        $("#registerForm").validate();
    });
</script>

</head>
<body>
    <form id="registerForm" method="get" action="">
        <fieldset>
            <p>
                <label for="cusername">用户名</label> 
                <input id="cusername" name="username" type="text" required="true" rangelength="[2,10]">
            </p>
            <p>
                <label for="cpassword">密码</label>
                <input id="cpassword" name="password" type="password" required="true" minlength="6">
            </p>
            <p>
                <label for="cconfirmpassword">确认密码</label> 
                <input id="cconfirmpassword" name="confirmpassword" type="password" required="true" equalTo="#cpassword">
            </p>
            <p>
                <label for="cemail">邮箱</label> 
                <input id="cemail" name="email" required="true" email="true"> </input>
            </p>
            <p>
                <input type="submit" value="提交">
            </p>
        </fieldset>
    </form>
</body>
</html>
JV1.HTML

事实证明,只引入上面的两个JS文件也能完成简单的表单验证。

2、不过由于默认的提示语句是英文的,所以,接下来要做的就是让提示显示成中文了。

方法一、通过javascript自定义验证规则。

技术分享
<!DOCTYPE html>
<html>
<head>
<script src="js/jquery.js"></script>
<script src="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>
    <form id="registerForm" method="get" action="">
        <fieldset>
            <p>
                <label for="cusername">用户名</label> 
                <input id="cusername" name="username" type="text"/>
            </p>
            <p>
                <label for="cpassword">密码</label> 
                <input id="cpassword" name="password" type="password"/>
            </p>
            <p>
                <label for="cconfirmpassword">确认密码</label> 
                <input id="cconfirmpassword" name="confirmpassword" type="password"/>
            </p>
            <p>
                <label for="cemail">邮箱</label>
                <input id="cemail" name="email" type="email"/>
            </p>
            <p>
                <input type="submit" value="提交">
            </p>
        </fieldset>
    </form>
</body>
</html>
JV2-1.HTML

以上有一点需要特别注意的就是  equalTo:"#cpassword",这个后面跟着的是元素的ID值(如果注意到#号就应该能察觉到),而别的key则是元素的name属性的值。例如username,confirmpassword等等。

那你可能会有疑问了,难道我每次验证表单都要自己重新自定义一次规则吗?当然不是了,你还可以Ctrl C,Ctrl V。这当然是玩笑话。。。

接下来的方法二会解决你的疑问。

 

方法二、自己翻译一份提示,作为模板,然后在需要的页面直接引入,十分方便。我是从网上下载了一份。

技术分享
(function( factory ) {
    if ( typeof define === "function" && define.amd ) {
        define( ["jquery", "../jquery.validate"], factory );
    } else {
        factory( jQuery );
    }
}(function( $ ) {

/*
 * Translated default messages for the jQuery validation plugin.
 * 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} 的数值")
});

}));
messages_zh.js

页面的代码和JV1.HTML几乎是一模一样,只是多引入了一份JS文件。

技术分享
<!DOCTYPE html>
<html>
<head>
<script src="js/jquery.js"></script>
<script src="js/jquery.validate.js"></script>
<script src="js/messages_zh.js"></script> 
<script>
    $().ready(function() {
        $("#registerForm").validate();
    });
</script>

</head>
<body>
    <form id="registerForm" method="get" action="">
        <fieldset>
            <p>
                <label for="cusername">用户名</label> 
                <input id="cusername" name="username" type="text" required="true" rangelength="[2,10]">
            </p>
            <p>
                <label for="cpassword">密码</label>
                <input id="cpassword" name="password" type="password" required="true" minlength="6">
            </p>
            <p>
                <label for="cconfirmpassword">确认密码</label> 
                <input id="cconfirmpassword" name="confirmpassword" type="password" required="true" equalTo="#cpassword">
            </p>
            <p>
                <label for="cemail">邮箱</label> 
                <input id="cemail" name="email" required="true" email="true"> </input>
            </p>
            <p>
                <input type="submit" value="提交">
            </p>
        </fieldset>
    </form>
</body>
</html>
JV2-2.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
默认校验规则

好了,摸摸索索了近两个小时,我的第一篇随笔到这也算是完成了。

C - jQuery Validate初体验(一)

标签:

原文地址:http://www.cnblogs.com/xiancheng/p/5034423.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!