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

OA项目之Jquery客户端验证

时间:2014-09-20 21:25:49      阅读:273      评论:0      收藏:0      [点我收藏+]

标签:jquery   jquery插件   treeview   json   插件   

1.今天做下验证方面的笔记

2.首先做的是客户端这一方的验证,为什么需要客户端的验证,是为了减轻服务器端的压力,可以利用Jquery的 validate插件来做,前面有个treeview插件来做树状显示,道理相同,利用Jquery插件来做很方便,简洁。

3.先看下效果图,类似如此的提示效果

bubuko.com,布布扣

①Jquery.validate是jquery旗下的一个验证框架,借助jquery的优势,我们可以迅速验证一些常见的输入,还可以自己扩充自己的验证方法,并且对国际化也有很好的支持。

②如何使用Jquery插件步骤:

     第一步:导入的jQuery.js与jquery.validate.js等文件,注意顺序不要颠倒

     

<script type="text/javascript" src="jquery.js">
<script type="text/javascript" src="jquery.metadata.js">
<script type="text/javascript" src="jquery.validate.js">
     

     第二步:指定哪个(或哪些)表单要在提交前先进行验证

<script type="text/javascript">
   		$(function(){
        	$("#testForm").validate();
    	});
</script>
   

     第三步:指定每个字段的验证规则

     

名称 *<input type="text" name="loginName" class="required">
其中class="required" 表示本字段必须要填写。
 

   效果如下图:

             bubuko.com,布布扣

③下面详细说明下验证规则的的方式

    1.把验证规则写到字段元素的class属性中

例如:

 

用户名:<input type="password" name="password" class="required">
电子邮件:<input type="text" name="email" class="required email">
密码:<input type="password" name="password" id="password1"
class="{required: true, minlength: 3}">
再次输入密码:<input type="password" name="password2" 
class="{equalTo:'[#password1]'} required">
    

以上用了两种方式:
1, 指定多个class名称(验证规则),多个class名称之间用空格隔开,如:class="required email"。
2, 使用JSON对象,指定多个属性,如:class="{required: true, minlength: 3}"。可以为某验证规则指定所用的参数,如minlength规则需要指定最小长度,这里为3。
3, 混合使用,如:class="{equalTo:‘[#password1]‘} required"。
 
说明:

1, 如果使用第2种方式(JSON对象),就必须引入:jquery.metadata.js,作用是解析JSON对象。

2, 如果表单字段的name不能重复,则只有最前面的配置起作用。



可以使用哪些验证规则(内置的验证规则)

bubuko.com,布布扣

说明:

1.remote是远程验证。比如注册验证用户名是否已被注册,返回值只能是true(验证成功)或false(验证失败)。在访问指定的url时,会自动把当前字段的值做为参数传递过去(以字段的name值为key,value为参数值)。

2.例如使用remote验证用户名是否存在,当添加一个用户后,在当前窗口中(同一个窗口),再次添加一个同名的用户,validate不能提示该用户已存在,这是因为缓存的原因,jquery仍认为该用户名可用。解决方法是在页面中添加如下代码:
    $().ready(function(){
        $.ajaxSetup ({
                cache: false //关闭ajax相应的缓存
         });
     });

3.某些属性值中的引号不能省略,否则出错。如accept、equalTo等,因为这时他需要的是一个字符串。

⑤有关错误提示消息

1.更改默认的错误提示消息

jQuery.extend(jQuery.validator.messages, {

    required: "请填写本字段",

    remote: "验证失败",

    email: "请输入正确的电子邮件",

    url: "请输入正确的网址",

    date: "请输入正确的日期",

    dateISO: "请输入正确的日期 (ISO).",

    number: "请输入正确的数字",

    digits: "请输入正确的整数",

    creditcard: "请输入正确的信用卡号",

    equalTo: "请再次输入相同的值",

    accept: "请输入指定的后缀名的字符串",

    maxlength: jQuery.validator.format("允许的最大长度为 {0} 个字符"),

    minlength: jQuery.validator.format("允许的最小长度为 {0} 个字符"),

    rangelength: jQuery.validator.format("允许的长度为{0}{1}之间"),

    range: jQuery.validator.format("请输入介于 {0} 和 {1} 之间的值"),

    max: jQuery.validator.format("请输入一个最大为 {0} 的值"),

    min: jQuery.validator.format("请输入一个最小为 {0} 的值")

});

2. 仅对当前表单改变提示消息

方法一:在class中指定某验证规则的错误消息

<input type="file" name="parResource" 

class="{
  required: true, accept: ‘zip‘, 
  messages: {required: ‘请选择文件‘, accept:‘请选择正确的文件‘}
}">    (提示:使用时不能换行)

 

方法二:在调用validate()方法时指定某验证规则的错误消息

$(function() {

    $("#myForm").validate({

        messages:{

            username:{ required: "填写用户名" }, 

            email: { required: ‘填写email‘, email: "填与确的email"}

        }

    });

});

3. 设置错误消息的显示样式

指定label.error的样式就可以了,如下:

<style type="text/css">

    label.error{

        margin-left: 10px;

        color: red;

    }

</style>

 

说明:label.errorclasserrorlabel元素,如:
<label for="username" class="error">


 最后把所有的文件包括插件和文档打包上传分享给大家!

http://download.csdn.net/my/uploads


OA项目之Jquery客户端验证

标签:jquery   jquery插件   treeview   json   插件   

原文地址:http://blog.csdn.net/dq3wrr/article/details/39433599

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