修改jQuery Validation里默認(rèn)的驗(yàn)證方法
更新時(shí)間:2012年02月14日 21:20:59 作者:
在最近做的一個(gè)項(xiàng)目中,使用jQuery Validation驗(yàn)證日期,遇到的問題和一個(gè)沒有預(yù)料到的情況是,在ASP.NET MVC 3的項(xiàng)目中,對(duì)于 input type="date" data-val="true"的元素,如果調(diào)用form的valid方法驗(yàn)證form,雖然我沒有添加日期驗(yàn)證的設(shè)置
在最近做的一個(gè)項(xiàng)目中,使用jQuery Validation驗(yàn)證日期,遇到的問題和一個(gè)沒有預(yù)料到的情況是,在ASP.NET MVC 3的項(xiàng)目中,對(duì)于 <input type="date" data-val="true" />的元素,如果調(diào)用form的valid方法驗(yàn)證form,雖然我沒有添加日期驗(yàn)證的設(shè)置,僅僅type="date",但其依然調(diào)用了日期驗(yàn)證邏輯來驗(yàn)證日期格式是否正確。這本來是個(gè)不錯(cuò)的行為,但問題在于,其支持的日期格式有限,閱讀jQuery Validation的代碼會(huì)知道(當(dāng)然,文檔中也有說明),對(duì)于“date”,日期驗(yàn)證只是利用Javascript內(nèi)置的處理來驗(yàn)證,反映到代碼里,就是看new Date(日期字符串)能否成功。在我的電腦中,輸入日期"9/5/2012"可以驗(yàn)證通過,但“2012-9-5”驗(yàn)證失敗,后者顯然也是一種正確的格式。我需要改變或者改善這種行為。如何做?
當(dāng)然,我們可以修改jQuery Validation的源代碼,但是首先,我引用的是CDN上的代碼,其次,作為一個(gè)public的庫(kù),我想還是盡量不要自己去改動(dòng),日久天長(zhǎng),可能我們已經(jīng)忘記了對(duì)它的修改,而官方更新新版本時(shí),我們弄下來更新,結(jié)果就把我們自己的修改給覆蓋了。更好的辦法,是打補(bǔ)丁,從外部把date的驗(yàn)證函數(shù)替換成我們自己的。這里或許要感謝Javascript的OO還不是那么徹底,并沒有把那些內(nèi)置驗(yàn)證方法整成protected/private,看了源代碼之后,替換的方法很簡(jiǎn)單,在引用jQuery Validation的源碼之后,再這樣替換:
$.validator.methods.date = function (value, element)
{
// Date.parse函數(shù)源自另外一個(gè)處理日期的庫(kù)
return this.optional(element) || Date.parse(value) != null;
};
此外替換默認(rèn)的message,也可以用同樣的辦法,比如:
$.validator.messages.date = "hey, you entered an invalid date"
當(dāng)然,處理messages有其他支持的更好的辦法,這在jQuery Validation的全球化和本地化的說明中有提及。
當(dāng)然,我們可以修改jQuery Validation的源代碼,但是首先,我引用的是CDN上的代碼,其次,作為一個(gè)public的庫(kù),我想還是盡量不要自己去改動(dòng),日久天長(zhǎng),可能我們已經(jīng)忘記了對(duì)它的修改,而官方更新新版本時(shí),我們弄下來更新,結(jié)果就把我們自己的修改給覆蓋了。更好的辦法,是打補(bǔ)丁,從外部把date的驗(yàn)證函數(shù)替換成我們自己的。這里或許要感謝Javascript的OO還不是那么徹底,并沒有把那些內(nèi)置驗(yàn)證方法整成protected/private,看了源代碼之后,替換的方法很簡(jiǎn)單,在引用jQuery Validation的源碼之后,再這樣替換:
復(fù)制代碼 代碼如下:
$.validator.methods.date = function (value, element)
{
// Date.parse函數(shù)源自另外一個(gè)處理日期的庫(kù)
return this.optional(element) || Date.parse(value) != null;
};
此外替換默認(rèn)的message,也可以用同樣的辦法,比如:
復(fù)制代碼 代碼如下:
$.validator.messages.date = "hey, you entered an invalid date"
當(dāng)然,處理messages有其他支持的更好的辦法,這在jQuery Validation的全球化和本地化的說明中有提及。
您可能感興趣的文章:
- jQuery插件Validation快速完成表單驗(yàn)證的方式
- jQuery Validation Plugin驗(yàn)證插件手動(dòng)驗(yàn)證
- jQuery Validation PlugIn的使用方法詳解
- jquery插件validation實(shí)現(xiàn)驗(yàn)證身份證號(hào)等
- jquery validation驗(yàn)證身份證號(hào),護(hù)照,電話號(hào)碼,email(實(shí)例代碼)
- ASP.NET中實(shí)現(xiàn)jQuery Validation-Engine的Ajax驗(yàn)證
- ASP.NET中實(shí)現(xiàn)jQuery Validation-Engine的Ajax驗(yàn)證實(shí)現(xiàn)代碼
- jQuery.Validate 使用筆記(jQuery Validation范例 )
- jQuery 表單驗(yàn)證插件formValidation實(shí)現(xiàn)個(gè)性化錯(cuò)誤提示
- jQuery插件之validation插件
相關(guān)文章
jquery實(shí)現(xiàn)Ctrl+Enter提交表單的方法
這篇文章主要介紹了jquery實(shí)現(xiàn)Ctrl+Enter提交表單的方法,涉及jquery針對(duì)鍵盤按鍵的響應(yīng)與表單操作相關(guān)技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-07-07jQuery前臺(tái)數(shù)據(jù)獲取實(shí)現(xiàn)代碼
jQuery前臺(tái)數(shù)據(jù)獲取實(shí)現(xiàn)代碼,需要的朋友可以參考下。2011-03-03兩種方法基于jQuery實(shí)現(xiàn)IE瀏覽器兼容placeholder效果
這篇文章主要介紹了兩種方法基于jQuery實(shí)現(xiàn)IE瀏覽器兼容placeholder效果,需要的朋友可以參考下2014-10-10Jquery使用Firefox FireBug插件調(diào)試Ajax步驟講解
本文介紹Jquery下的Ajax調(diào)試方法,Jquery Ajax 提供了全功能的 $.ajax() 方法,還有諸如 $.get(),$.getScript(),$.getJSON(),$.post() 和 $().load() 等更為簡(jiǎn)便的方法2013-12-12jQuery獲取訪問者IP地址的方法(基于新浪API與QQ查詢接口)
這篇文章主要介紹了jQuery獲取訪問者IP地址的方法,實(shí)例分析了jQuery基于新浪API與QQ查詢接口獲取來訪者IP的相關(guān)參數(shù)傳遞與數(shù)據(jù)處理技巧,需要的朋友可以參考下2016-05-05jquery實(shí)現(xiàn)的動(dòng)態(tài)回到頂部特效代碼
這篇文章主要介紹了jquery實(shí)現(xiàn)的動(dòng)態(tài)回到頂部特效代碼,涉及jQuery基于時(shí)間函數(shù)的定時(shí)遞歸調(diào)用實(shí)現(xiàn)帶緩沖效果的移動(dòng)功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10