麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

jQuery驗證插件 Validate詳解

2019-11-20 13:54:42
字體:
來源:轉載
供稿:網友

最常使用JavaScript的場合就是表單的驗證,而jQuery作為一個優秀的JavaScript庫,也提供了一個優秀的表單驗證插件----Validation。Validation是歷史最悠久的jQuery插件之一,經過了全球范圍內不同項目的驗證,并得到了許多Web開發者的好評。作為一個標準的驗證方法庫,Validation擁有如下特點:

1.內置驗證規則: 擁有必填、數字、Email、URL和信用卡號碼等19類內置驗證規則
2.自定義驗證規則: 可以很方便地自定義驗證規則
3.簡單強大的驗證信息提示: 默認了驗證信息提示,并提供自定義覆蓋默認的提示信息的功能
4.實時驗證: 可能通過keyup或blur事件觸發驗證,而不僅僅在表單提交的時候驗證

validate.js下載地址: http://plugins.jquery.com/project/validate
metadata.js下載地址: http://plugins.jquery.com/project/metadata
使用方法:
1.引入jQuery庫和Validation插件

復制代碼 代碼如下:

<script src="scripts/jquery-1.6.4.js" type="text/javascript"></script> 
<script src="scripts/jquery.validate.js" type="text/javascript"></script>

2.確定哪個表單需要被驗證

復制代碼 代碼如下:

<script type="text/javascript"> 
////<![CDATA[ 
$(document).ready(function(){ 
    $("#commentForm").validate(); 
}); 
//]]> 
</script> 

3.針對不同的字段,進行驗證規則編碼,設置字段相應的屬性

復制代碼 代碼如下:

class="required"   必須填寫 
class="required email"        必須填寫且內容符合Email格式驗證 
class="url"             符合URL格式驗證 
minlength="2"      最小長度為2 
可驗證的規則有19種:
[javascript] view plaincopyprint?
required:      必選字段 
remote:        "請修正該字段", 
email:         電子郵件驗證 
url:           網址驗證 
date:          日期驗證 
dateISO:       日期 (ISO)驗證 
dateDE: 
number:        數字驗證 
numberDE: 
digits:        只能輸入整數 
creditcard:    信用卡號驗證 
equalTo:       ”請再次輸入相同的值“驗證 
accept:        擁有合法后綴名的字符串驗證 
maxlength/minlength:    最大/最小長度驗證 
rangelength:     字符串長度范圍驗證 
range:           數字范圍驗證 
max/min:         最大值/最小值驗證 

需要引入的js

復制代碼 代碼如下:

<script type="text/javascript" src="../../scripts/jquery-1.3.1.js"></script>
<script type="text/javascript" src="lib/jquery.validate.js"></script>

初始化的HTML

復制代碼 代碼如下:

<script type="text/javascript">
$(function(){
 $("#commentForm").validate()
})
</script>
<form class="cmxform" id="commentForm" method="get" action="">
 <fieldset>
   <legend>一個簡單的validate驗證帶驗證提示的評論例子</legend>
   <p>
     <label for="cusername">姓名</label>
     <em>*</em><input id="cusername" name="username" size="25" class="required" minlength="2" />
   </p>
   <p>
     <label for="cemail">電子郵件</label>
     <em>*</em><input id="cemail" name="email" size="25" class="required email"  />
   </p>
   <p>
     <label for="curl">網址</label>
     <em>  </em><input id="curl" name="url" size="25" class="url" />
   </p>
   <p>
     <label for="ccomment">你的評論</label>
     <em>*</em><textarea id="ccomment" name="comment" cols="22" class="required" ></textarea>
   </p>
 <p>
     <input class="submit" type="submit" value="提交"/>
   </p>

首先看默認設置的規格

序號 規則 描述
1 required:true 必須輸入的字段。
2 remote:"check.php" 使用 ajax 方法調用 check.php 驗證輸入值。
3 email:true 必須輸入正確格式的電子郵件。
4 url:true 必須輸入正確格式的網址。
5 date:true 必須輸入正確格式的日期。日期校驗 ie6 出錯,慎用。
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。

required表示必須填寫的

email表示必須正確的郵箱

把驗證的規格寫在HTML內的class內,方法欠妥,后期的維護增加成本,沒有實現行為與結構的分離

所以,可以想把HTML內的class都清空,如下:

復制代碼 代碼如下:

<form class="cmxform" id="commentForm" method="get" action="">
 <fieldset>
   <legend>一個簡單的validate驗證帶驗證提示的評論例子</legend>
   <p>
     <label for="cusername">姓名</label>
     <em>*</em><input id="cusername" name="username" size="25" />
   </p>
   <p>
     <label for="cemail">電子郵件</label>
     <em>*</em><input id="cemail" name="email" size="25"  />
   </p>
   <p>
     <label for="curl">網址</label>
     <em>  </em><input id="curl" name="url" size="25" />
   </p>
   <p>
     <label for="ccomment">你的評論</label>
     <em>*</em><textarea id="ccomment" name="comment" cols="22" ></textarea>
   </p>
 <p>
     <input class="submit" type="submit" value="提交"/>
   </p>

js

復制代碼 代碼如下:

 $(document).ready(function(){
    $("#commentForm").validate({
      rules:{
        username:{
          required:true,
          minlength:2
        },
        email:{
          required:true,
          email:true
        },
        url:"url",
        comment:"required",
        valcode: {
          formula: "7+9" 
        }
      }
    });
  });
  </script>

因為默認的提示是英文的,可以改寫成

復制代碼 代碼如下:

jQuery.extend(jQuery.validator.messages, {
        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} 的值")
});

建議新建一個js,放到validate.js 下面.

關于提示的美化

復制代碼 代碼如下:

errorElement:"em"

  創建一個標簽,可以自定義

復制代碼 代碼如下:

success:function(label){
        label.text(" ").addClass('success')
      }

這里的參數label是指向創建的標簽,這里也就是”em“ 然后情況自己的內容,在加上自己的class就可以了

完整的js

復制代碼 代碼如下:

  $("#commentForm").validate({
      rules:{
        username:{
          required:true,
          minlength:2
        },
        email:{
          required:true,
          email:true
        },
        url:"url",
        comment:"required",
      },
      errorElement:"em",
      success:function(label){
        label.text(" ").addClass('success')
      }
    });

相對應的css

復制代碼 代碼如下:

em.error {
  background:url("images/unchecked.gif") no-repeat 0px 0px;
  padding-left: 16px;
}
em.success {
  background:url("images/checked.gif") no-repeat 0px 0px;
  padding-left: 16px;
}

.success放到.error下面。。。唔唔。。具體的情況。。只可體會不可言會。。唔。。

在做項目的過程中千變萬化,有時候要滿足不同的需求,validate也可以單獨的修改驗證的信息。。

例如:

復制代碼 代碼如下:

  messages:{
        username:{
          required:"主人,我要填的滿滿的",
          minlength:"哎唷,長度不夠耶"
        }
   }

完整的js

復制代碼 代碼如下:

 $("#commentForm").validate({
      rules:{
        username:{
          required:true,
          minlength:2
        },
        email:{
          required:true,
          email:true
        },
        url:"url",
        comment:"required",
        valcode: {
          formula: "7+9" 
        }
      },
      messages:{
        username:{
          required:"主人,我要填的滿滿的",
          minlength:"哎唷,長度不夠耶"
        }
      },
      errorElement:"em",
      success:function(label){
        label.text(" ").addClass('success')
      }
    });

這里就可以啦。

關于自定義驗證規則

增加一段HTML代碼

復制代碼 代碼如下:

 <p>
     <label for="cvalcode">驗證碼</label>
     <input id="valcode" name="valcode"  />=7+9
   </p>

自定一個規則

復制代碼 代碼如下:

$.validator.addMethod("formula",function(value,element,param){
      return value==eval(param)
    },"請正確輸入驗證信息");

formula是需要驗證方法的名字 好比如required 必須的。
value返回的當前input的value值
param返回的是當前自定義的驗證格式 好比如:7+9
在試用了eval方法 讓字符串相加

完整的js

復制代碼 代碼如下:

$.validator.addMethod("formula",function(value,element,param){
      return value==eval(param)
    },"請正確輸入驗證信息");
    $("#commentForm").validate({
      rules:{
        username:{
          required:true,
          minlength:2
        },
        email:{
          required:true,
          email:true
        },
        url:"url",
        comment:"required",
        valcode: {
          formula: "7+9" 
        }
      },
      messages:{
        username:{
          required:"主人,我要填的滿滿的",
          minlength:"哎唷,長度不夠耶"
        }
      },
      errorElement:"em",
      success:function(label){
        label.text(" ").addClass('success')
      }
    });

額。。沒了 學的不深,這是基礎的一部分。。還會繼續深入學習去。掰掰( ^_^ )/~~拜拜

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日韩a毛片免费观看 | 国产精品久久久久久久久久久久久久久久 | 国产午夜精品一区二区三区四区 | 亚洲视频综合 | 九九热在线精品视频 | 国产精品久久国产精品 | 亚洲性生活免费视频 | 亚洲国产高清自拍 | 久久毛片 | 成人在线免费观看视频 | 法国极品成人h版 | 国产88久久久国产精品免费二区 | 精品久久久久久久久久中出 | 精品一区二区久久久久 | 91网址在线播放 | 懂色粉嫩av久婷啪 | 亚洲国产精品久久久久久久久久久 | 国产亚洲精品久久久久5区 综合激情网 | 国产精品久久久久久久久久东京 | 国产伦精品一区二区三区在线 | 亚洲精中文字幕二区三区 | 蜜桃视频在线观看视频 | 精品在线视频播放 | 久色乳综合思思在线视频 | 精品国产一区二区三区久久久蜜月 | 久久国产夫妻视频 | 色无极影院亚洲 | 一级做人爱c黑人影片 | 成人毛片网站 | 亚洲第一成人在线 | 日本在线播放一区二区三区 | 国产成人午夜精品 | 操穴视频 | av在线免费看片 | 成人福利网 | 干一夜综合 | 亚洲国产高清一区 | 免费在线观看国产精品 | 久久精品成人影院 | 综合日韩欧美 | 欧美一区二区三区久久精品视 |