一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - jQuery驗證插件 Validate詳解

jQuery驗證插件 Validate詳解

2021-04-21 16:50jQuery教程網 JavaScript

validate是一款很好的jq插件,提供了強大的驗證功能,讓客戶端表單驗證變得更簡單,同時提供了大量的定制選項,滿足應用程序各種需求。該插件捆綁了一套有用的驗證方法,包括 URL 和電子郵件驗證,同時提供了一個用來編寫用戶

最常使用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 下面.

關于提示的美化

jQuery驗證插件 Validate詳解

 

復制代碼 代碼如下:

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')
      }
    });

 

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲乱人伦在线 | 日日插插 | 成年私人影院免费视频网站 | 精品国产品香蕉在线观看75 | 亚洲精品在看在线观看 | 亚洲首页国产精品丝袜 | 黑帮少爷爱上我第8集在线观看 | 91免费破解版 | 国产精品视频一区二区三区w | 日韩精品一区二区 | 日本黄色大片网站 | free哆拍拍免费永久视频 | 国产精品极品美女自在线 | 国模孕妇季玥全部人体写真 | 国产人成精品午夜在线观看 | 欧美成人乱弄视频 | h卡通第一页| 日本动漫打扑克动画片樱花动漫 | 国产青青操 | 91最新国产 | 亚洲AV蜜桃永久无码精品红樱桃 | 亚欧美综合 | 国产成人影院在线观看 | 免费看片黄色 | 国产精品高清视亚洲一区二区 | 国产成人欧美视频在线 | 日本嫩模 | 亚洲 欧美 国产 综合首页 | 国产精品原创永久在线观看 | 美女的隐私无遮挡的网页 | 亚洲AV永久无码精品老司机蜜桃 | 国产真实伦对白在线播放 | 亚洲视频中文 | 午夜在线a亚洲v天堂网2019 | 欧美四虎影院 | 好大好爽好硬我要喷水了 | 摸咪网在线影院在线观看 | 动态图啪啪120秒免费看 | 美女脱了内裤打开腿让你桶爽 | 亚洲国产精品婷婷久久久久 | 99成人免费视频 |