亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

jQuery Validate初步體驗(二)

2019-11-20 11:01:56
字體:
來源:轉載
供稿:網友

在上篇文章給大家介紹了jQuery Validate初步體驗(一) ,本文繼續給大家分享jquery validate相關知識,對本文感興趣的朋友快來學習吧。

剛剛試了所謂的新版的用法。千萬別問我是多新,因為我也不知道。。。

<!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" data-rule-required="true" data-rule-rangelength="[2,10]" data-msg-required="用戶名不能為空" data-msg-rangelength="用戶名長度必須是{0}到{1}個字符">   </p>   <p>    <label for="cpassword">密碼</label>     <input id="cpassword" name="password" type="password" data-rule-required="true" data-rule-minlength="6" data-msg-required="密碼不能為空" data-msg-minlength="密碼必須不少于{0}位">   </p>   <p>    <label for="cconfirmpassword">確認密碼</label>     <input id="cconfirmpassword" name="confirmpassword" type="password" data-rule-required="true" data-rule-equalTo="#cpassword" data-msg-required="請再次輸入密碼" data-msg-equalTo="兩次輸入的密碼不一致">   </p>   <p>    <label for="cemail">郵箱</label>     <input id="cemail" name="email" data-rule-required="true" data-rule-email="true" data-msg-required="郵箱不能為空" data-msg-email="郵箱的格式不正確"/>   </p>   <p>    <input type="submit" value="提交">   </p>  </fieldset> </form></body></html> 

 個人感覺這種用法比通過javascript自定義驗證規則,要方便和簡單多了。昨天在剛開始自定義的時候,總是無法正確的提示,當時完全不知道為什么。直到檢查了多遍才發現,原來是因為我的rules里的鍵值對之間漏了一個逗號。所以,如果默認的校驗規則已經滿足你的驗證需求,而你只是想改變一下提示語。那我個人建議你用這種新版的用法,當然也可以用 系列(一) 里的方法

二。具體看情況自己選擇。

還有我上面的提示都是默認的黑色,身為提示,那樣也太沒存在感了。

為了增加存在感,你只需要在<head></head>之間插入下面的代碼就可以了。

<style> #registerForm label.error{  margin-left: 10px;  color:red; }</style> 

請注意上面的#號后面跟著是表單的ID,你需要改成你自己相應的表單ID。我昨天嘗試的時候,找到的資料里寫的是#frm。當時我還以為#frm又是我沒接觸過的新用法呢,我還一直疑惑,為什么我的提示不顯示成紅色?;A差哎。。。

如果默認的驗證規則已經不能滿足你的需求,那么接下來,你就得自定義驗證規則了。

比如,這里有一個需求,要你檢查用戶輸入的郵編是否合法,這時你就得自定義驗證規則了,使用的方法是jQuery.validator.addMethod()。

<!DOCTYPE html><html><head><script src="js/jquery.js"></script><script src="js/jquery.validate.js"></script><script> $().ready(function() {  jQuery.validator.addMethod("isZipCode", function(value, element) {   var tel = /^[0-9]{6}$/;   return this.optional(element) || (tel.test(value));  }, "請正確填寫您的郵政編碼");  $("#registerForm").validate({   rules : {    zipCode : {     required : true,//對于required的提示語句沒有進行任何的處理,他會使用默認的英文的提示。     isZipCode : true//isZipCode為自定義的驗證規則    }   },   messages : {//當你不寫提示語句,他會使用上面方法返回的提示。    zipCode : {     isZipCode : '請輸入正確的郵編'    }   }  }); });</script><style>#registerForm label.error { margin-left: 10px; color: red;}</style></head><body> <form id="registerForm" method="get" action="">  <fieldset>   <p>    <label for="czipCode">中國郵編</label>     <input id="czipCode" name="zipCode" />   </p>   <p>    <input type="submit" value="提交">   </p>  </fieldset> </form></body></html> 

當然,你也可以把這個驗證規則提取出來存到一個JS文件里,然后在要用的地方引入JS文件。

jQuery.validator.addMethod("isZipCode", function(value, element) { var tel = /^[0-9]{6}$/; return this.optional(element) || (tel.test(value));}, "請正確填寫您的郵政編碼"); <!DOCTYPE html><html><head><script src="js/jquery.js"></script><script src="js/jquery.validate.js"></script><script src="js/validate.expand.js"></script><script> $().ready(function() {  $("#registerForm").validate({   rules : {    zipCode : {     required : true,//對于required的提示語句沒有進行任何的處理,他會使用默認的英文的提示。     isZipCode : true//isZipCode為自定義的驗證規則    }   },   messages : {//當你不寫提示語句,他會使用方法返回的提示。    zipCode : {     isZipCode : '請輸入正確的郵編'    }   }  }); });</script><style>#registerForm label.error { margin-left: 10px; color: red;}</style></head><body> <form id="registerForm" method="get" action="">  <fieldset>   <p>    <label for="czipCode">中國郵編</label>     <input id="czipCode" name="zipCode" />   </p>   <p>    <input type="submit" value="提交">   </p>  </fieldset> </form></body></html> 

 接下來,就要好好說說jQuery.validator.addMethod() 這個方法,這個方法一共有三個參數。

第一個參數 :“isZipCode” 是定義方法名,必須保證方法名唯一。

第二個參數:是一個回調(callback)函數。

  這個回調函數有三個參數:

    第一個:value ,是當前被驗證的元素的值。

    第二個:element,是當前被驗證的元素。

    第三個:param,是傳入的參數,例如: minlength : 6  里的參數為6;  rangelength:[2,10]  里的參數為2和10。當你沒有傳入參數,這個可以省略不寫。

    在這個回調函數里有一個this.optional(element)函數要特別注意。當表單的輸入值為空時,即element的值為空,this.optional(element)的返回值為true,類似于判空操作,也就是說該表單輸入項不是必填項,當不填時通過了驗證。如果element的值不為空,this.optional(element)的返回值就是false,這時就要根據  ||  后面的驗證來判斷最終的返回為true 或false。所以當某個輸入項不是必填項但如果填寫了又需要按照一定的規則來驗證的時候,一定要記得帶上this.optional(element)。

第三個參數:驗證的提示信息。

  這個參數可以直接是一句提示信息,例如,"這是必填字段";也可以通過創建函數jQuery.validator.format(value)來顯示,例如,$.validator.format("請輸入長度在 {0} 到 {1} 之間的字符串"),其中 {0} {1} 代表該方法的參數,也就是回調(callback)函數里的第三個參數param。

官網提供的additional-methods.js里包含一些常用的驗證方式,比如lettersonly,ziprange,nowhitespace等,但我粗略的看了一下,發現大部分只是僅供參考,實用性不強,不能直接使用。

我整理了幾個網上找到的驗證規則,當然也僅供參考。驗證規則的核心就是正則表達式,這個得學。

// 郵政編碼驗證 jQuery.validator.addMethod("isZipCode", function(value, element) {var tel = /^[0-9]{6}$/;return this.optional(element) || (tel.test(value));}, "請正確填寫您的郵政編碼");// 手機號碼驗證 jQuery.validator.addMethod("mobile", function(value, element) { var length = value.length;var mobile = /^(13[0-9]|14[0-9]|15[0-9]|18[0-9])/d{8}$/;return this.optional(element) || (length == 11 && mobile.test(value)); }, "手機號碼格式錯誤"); // QQ號碼驗證 jQuery.validator.addMethod("qq", function(value, element) { var tel = /^[1-9]/d{4,10}$/; return this.optional(element) || (tel.test(value)); }, "qq號碼格式錯誤"); // IP地址驗證 jQuery.validator.addMethod("ip", function(value, element) { var ip = /^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)/.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/; return this.optional(element) || (ip.test(value) && (RegExp.$1 < 256 && RegExp.$2 < 256 && RegExp.$3 < 256 && RegExp.$4 < 256)); }, "Ip地址格式錯誤"); // 字母和數字的驗證 jQuery.validator.addMethod("chrnum", function(value, element) { var chrnum = /^([a-zA-Z0-9]+)$/; return this.optional(element) || (chrnum.test(value)); }, "只能輸入數字和字母(字符A-Z, a-z, 0-9)"); // 中文的驗證 jQuery.validator.addMethod("chinese", function(value, element) { var chinese = /^[/u4e00-/u9fa5]+$/; return this.optional(element) || (chinese.test(value)); }, "只能輸入中文"); 

如果有什么地方寫錯了或者寫的不夠好,希望大大們能提出來。還有,歡迎留言評論,一起學習。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久久久影院日本| 青青草国产精品一区二区| 成人免费网站在线看| 91在线视频一区| 欧美一级淫片播放口| 国产亚洲人成网站在线观看| 国产精品va在线播放我和闺蜜| 欧美在线观看视频| 精品福利免费观看| 国产精品吴梦梦| 国模gogo一区二区大胆私拍| 欧美壮男野外gaytube| 精品久久香蕉国产线看观看亚洲| 日韩精品中文字幕有码专区| 色妞欧美日韩在线| 亚洲成av人片在线观看香蕉| 欧美xxxx做受欧美| 亚洲最大的成人网| 欧美一级大片在线观看| 亚洲精品中文字| 国产精品久久久久久久av大片| 成人中文字幕在线观看| 欧美孕妇性xx| 美日韩精品视频免费看| 亚洲福利视频久久| 欧美精品免费看| 欧美精品一区在线播放| 一本色道久久综合狠狠躁篇怎么玩| 亚洲人成网7777777国产| 亚洲成人国产精品| 中文字幕精品www乱入免费视频| 日本久久久久久久| 亚洲国产精品人人爽夜夜爽| 国产精品第10页| 日韩理论片久久| 91精品啪在线观看麻豆免费| 久久亚洲综合国产精品99麻豆精品福利| 日韩欧美在线免费| 久久999免费视频| 97碰碰碰免费色视频| 欧美日韩国产色视频| 欧美视频在线观看免费| 日本欧美黄网站| 亚洲人成伊人成综合网久久久| 欧美日韩在线视频首页| 色一情一乱一区二区| 亚洲色图五月天| 亚洲国产高潮在线观看| 欧美激情免费在线| 成人在线视频网站| 日韩精品视频免费专区在线播放| 国产91色在线| 亚洲aa在线观看| 综合国产在线视频| 91精品国产一区| 久久久最新网址| 国产日韩精品一区二区| 久久久久久国产精品久久| 正在播放国产一区| 国产主播在线一区| 国产精品免费一区二区三区都可以| 亚洲a中文字幕| 亚洲自拍欧美色图| 亚洲欧洲成视频免费观看| 亚洲伊人成综合成人网| 成人中文字幕在线观看| 亚洲aⅴ日韩av电影在线观看| 57pao成人国产永久免费| 国产精国产精品| 日韩免费电影在线观看| 国产91久久婷婷一区二区| 成人黄色生活片| 日韩中文字幕精品| 亚洲在线观看视频| 久久久久久九九九| 中文字幕国产精品久久| 国产精品极品美女粉嫩高清在线| 欧美午夜丰满在线18影院| 亚洲成人黄色在线| 国产欧美日韩最新| 国模精品系列视频| 国产精品一二区| 亚洲精品98久久久久久中文字幕| 九九热视频这里只有精品| 国产精品久久久久77777| 久久久久久久激情视频| 国产亚洲福利一区| 亚洲人成网站色ww在线| 777777777亚洲妇女| 亚洲毛片在线免费观看| 热久久免费视频精品| 国产99久久精品一区二区永久免费| 激情成人中文字幕| 91美女片黄在线观看游戏| 国产一区欧美二区三区| 欧美亚州一区二区三区| 久久久av免费| 中文字幕日韩有码| 久久影院资源站| 国产一区二区三区日韩欧美| 国产精品三级美女白浆呻吟| 亚洲欧美日本精品| 亚洲国产天堂久久综合| 国产精品成人v| 热99精品里视频精品| 日韩国产高清污视频在线观看| 91国在线精品国内播放| 久久久久成人网| 亚洲欧洲偷拍精品| 色七七影院综合| 亚洲精品美女久久久| 欧洲一区二区视频| 欧美日韩在线免费| 菠萝蜜影院一区二区免费| 久久久精品国产| 国产一区二中文字幕在线看| 亚洲免费av片| 91免费版网站入口| 91精品国产高清久久久久久久久| 日韩中文字幕视频在线观看| 国产亚洲视频中文字幕视频| 亚洲自拍小视频| 久久久久久国产精品久久| 日本19禁啪啪免费观看www| 国产成人精品免高潮在线观看| 精品久久久久久中文字幕| 最近2019中文字幕mv免费看| 亚洲精品黄网在线观看| 亚洲理论片在线观看| 91精品国产综合久久香蕉的用户体验| 97视频在线观看免费高清完整版在线观看| 成人中文字幕+乱码+中文字幕| 色综合久久88| 欧洲永久精品大片ww免费漫画| 国产精品免费观看在线| 青青草成人在线| 亚洲美女av电影| 中文字幕亚洲色图| 日韩av快播网址| 亚洲精品视频二区| 欧美福利在线观看| 亚洲视频在线观看视频| 亚洲色图欧美制服丝袜另类第一页| 亚洲日本成人网| 国产精品18久久久久久首页狼| 久久亚洲精品毛片| 国产一区二区三区在线播放免费观看| 91wwwcom在线观看| 久久久久久久爱| 成人有码视频在线播放| 成人激情综合网| 色综合久久久久久中文网| 日韩成人中文字幕在线观看| 亚洲精品成人久久久| 中文字幕国内精品| 国产美女扒开尿口久久久| 一区二区三区视频观看| 亚洲精品久久久久中文字幕二区| 国产美女久久精品香蕉69| 久久久精品国产亚洲| 精品国产自在精品国产浪潮| 日韩精品免费在线视频| 久久综合免费视频| 青青青国产精品一区二区|