计算机教程

jquery.validate.js初体验

28 9月 , 2019  

<form id=”form1″ name=”form1″ method=”post” action=””>
  <label>name
  <input name=”name” type=”text” id=”name” />
  </label>
  <p>
    <label>birthday
    <input name=”birthday” type=”text” id=”birthday” />
    </label>
  </p>
  <p>
    <label>email
    <input name=”email” type=”text” id=”email” />
    </label>
  </p>
  <p>
    <label>
    <input type=”submit” name=”Submit” value=”submit” />
    </label>
  </p>
</form>
<?php
//这个函数主要用来检查提交的表单数据是否有错(validate)
//实际应用上用户输入数据的检验(validate)及过滤(filter)都涉到程序安全性,非常重要,必不可少
//在写实际应用时不会把$_POST直接放在函数里,这里是一个姑息的解决方法,希望大家能改正

参看:http://docs.jquery.com/Plugins/Validation并整理

if( $_POST )
{
 form_error();
}
function form_error() {
    $_POST[‘name’] = trim(strip_tags($_POST[‘name’]));
//这个实际上是Filter
    $len_name = strlen($_POST[‘name’]);
    if($len_name > 30 || $len_name < 2) {
        $msg = ‘姓名长度必须大于2小于30<br />’;
    }
    $date = explode(‘-‘, $_POST[‘birthday’]);
    if(sizeof($date) != 3) {
        $msg .= ‘日期格式错误<br />’;
    } else {
        if(!checkdate($date[1], $date[2], $date[0])) {
            $msg .= ‘日期不正确<br />’;
        }
    }
   
if(!eregi(“^[a-z’0-9]+([._-][a-z’0-9]+)*@([a-z0-9]+([._-][a-z0-9]+))+$”,
$_POST[’email’])) {
        $msg .= ‘邮箱格式错误’;
    }
    return $msg;
}
?>

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

使用这个函数很简单,看以下的代码

  1. <!DOCTYPE HTML PUBLIC “-//W3C//DTD HTML 4.01 Transitional//EN” 
      
  2.                     “http://www.w3.org/TR/html4/loose.dtd"**&gt;**  
  3. <html>  
  4. <head>  
  5.   <script src=”http://code.jquery.com/jquery-latest.js"**&gt;&lt;/script&gt;**  
  6.   <link rel=”stylesheet” href=”http://dev.jquery.com/view/trunk/plugins/validate/jquery.validate.css” type=”text/css” media=”screen” />  
  7. <script type=”text/javascript” src=”http://dev.jquery.com/view/trunk/plugins/validate/jquery.validate.js"**&gt;&lt;/script&gt;**  
  8. <style type=”text/css”>  
  9. * { font-family: Verdana; font-size: 96%; }   
  10. label { width: 10em; float: left; }   
  11. label.error { float: none; color: red; padding-left: .5em; vertical-align: top; }
      
  12. p { clear: both; }   
  13. .submit { margin-left: 12em; }   
  14. em { font-weight: bold; padding-right: 1em; vertical-align: top; }
      
  15. </style>  
  16.   <script>  
  17.   $(document).ready(function(){   
  18.     $(“#commentForm”).validate();   
  19.   });   
  20.   </script>  
  21.      
  22. </head>  
  23. <body>  
  24.      
  25.   
  26.  <form class=”cmxform” id=”commentForm” method=”get” action=””>  
  27.  <fieldset>  
  28.    <legend>A simple comment form with submit validation and default messages</legend>  
  29.    <p>  
  30.      <label for=”cname”>Name</label>  
  31.      <em>*</em><input id=”cname” name=”name” size=”25″ class=”required” minlength=”2″ />  
  32.    </p>  
  33.    <p>  
  34.      <label for=”cemail”>E-Mail</label>  
  35.      <em>*</em><input id=”cemail” name=”email” size=”25″  class=”required email” />  
  36.    </p>  
  37.    <p>  
  38.      <label for=”curl”>URL</label>  
  39.      <em>  </em><input id=”curl” name=”url” size=”25″  class=”url” value=”” />  
  40.    </p>  
  41.    <p>  
  42.      <label for=”ccomment”>Your comment</label>  
  43.      <em>*</em><textarea id=”ccomment” name=”comment” cols=”22″  class=”required”></textarea>  
  44.    </p>  
  45.    <p>  
  46.      <input class=”submit” type=”submit” value=”Submit”/>  
  47.    </p>  
  48.  </fieldset>  
  49.  </form>  
  50. </body>  
  51. </html>  

总结,我们只要在加入如下的JAVASCRIPT代码,就可以把指定的FORM加上验证

  1. $(document).ready(function(){   
  2.    $(“#commentForm”).validate();   
  3.  });  

 
不过我们还要在需要验证的INPUT里面class加入required说明是必填项,其他的就是验证相关数据比如email就是验证email的数据结构

以下列出validate自带的默认验证

 

        required: “必选字段”,
        remote: “请修正该字段”,
        email: “请输入正确格式的电子邮件”,
        url: “请输入合法的网址”,
        date: “请输入合法的日期”,
        dateISO: “请输入合法的日期 (ISO).”,
        number: “请输入合法的数字”,
        digits: “只能输入整数”,
        creditcard: “请输入合法的信用卡号”,
        equalTo: “请再次输入相同的值”,
        accept: “请输入拥有合法后缀名的字符串”,
        maxlength: jQuery.format(“请输入一个长度最多是 {0} 的字符串”),
        minlength: jQuery.format(“请输入一个长度最少是 {0} 的字符串”),
        rangelength: jQuery.format(“请输入一个长度介于 {0} 和 {1}
之间的字符串”),
        range: jQuery.format(“请输入一个介于 {0} 和 {1} 之间的值”),
        max: jQuery.format(“请输入一个最大为 {0} 的值”),
        min: jQuery.format(“请输入一个最小为 {0} 的值”)

 

validate()的可选项 debug:进行调试模式
$(“.selector”).validate
({
debug: true
})

把调试设置为默认
$.validator.setDefaults({
debug: true
})

submitHandler:用其他方式替代默认的SUBMIT,比如用AJAX的方式提交
$(“.selector”).validate
({
submitHandler: function(form) {
$(form).ajaxSubmit();
}
})

ignore:忽略某些元素不验证
$(“#myform”).validate
({
ignore: “.ignore”
})

rules: 默认下根据form的classes, attributes,
metadata判断,但也可以在validate函数里面声明
Key/value 可自定义规则. Key是对象的名字 value是对象的规则,可以组合使用
class/attribute/metadata rules.
以下代码特别验证selector类中name=’name’是必填项并且
email是既是必填又要符合email的格式
$(“.selector”).validate({
rules: {
// simple rule, converted to {required:true}
name: “required”,
// compound rule
email: {
required: true,
email: true
}
}
})

messages:更改默认的提示信息
$(“.selector”).validate
({
rules: {
name: “required”,
email: {
required: true,
email: true
}
},
messages: {
name: “Please specify your name”,
email: {
required: “We need your email address to contact you”,
email: “Your email address must be in the format of name@domain.com
}
}
})

groups:定义一个组,把几个地方的出错信息同意放在一个地方,用errorPlacement控制把出错信息放在哪里
$(“#myform”).validate ({
groups: { username: “fname lname” },
errorPlacement: function(error, element) {
if (element.attr(“name”) == “fname” || element.attr(“name”) == “lname”
)
error.insertAfter(“#lastname”);
else
error.insertAfter(element); },
debug:true
})

onsubmit Boolean  Default: true 
提交时验证. 设置为false就用其他方法去验证 
不用onsubmit验证,就允许用户无论用什么方法去验证,而是提交时, 用
keyup/blur/click 等方法.

$(“.selector”).validate({
   onsubmit: false
})
 
onfocusout Boolean  Default: true 
Validate elements (except checkboxes/radio buttons) on blur. If nothing
is entered, all rules are skipped, except when the field was already
marked as invalid.
Disables onblur validation.

$(“.selector”).validate({
   onfocusout: false
})
 
onkeyup Boolean  Default: true 
在keyup时验证. As long as the field is not marked as invalid, nothing
happens. Otherwise, all rules are checked on each key up event.
Disables onkeyup validation.

$(“.selector”).validate({
   onkeyup: false
})
 
onclick Boolean  Default: true 
在checkboxes 和 radio 点击时验证.
Disables onclick validation of checkboxes and radio buttons.


相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图