欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

修改jQuery Validation里默認的驗證方法

 更新時間:2012年02月14日 21:20:59   作者:  
在最近做的一個項目中,使用jQuery Validation驗證日期,遇到的問題和一個沒有預料到的情況是,在ASP.NET MVC 3的項目中,對于 input type="date" data-val="true"的元素,如果調(diào)用form的valid方法驗證form,雖然我沒有添加日期驗證的設置
在最近做的一個項目中,使用jQuery Validation驗證日期,遇到的問題和一個沒有預料到的情況是,在ASP.NET MVC 3的項目中,對于 <input type="date" data-val="true" />的元素,如果調(diào)用form的valid方法驗證form,雖然我沒有添加日期驗證的設置,僅僅type="date",但其依然調(diào)用了日期驗證邏輯來驗證日期格式是否正確。這本來是個不錯的行為,但問題在于,其支持的日期格式有限,閱讀jQuery Validation的代碼會知道(當然,文檔中也有說明),對于“date”,日期驗證只是利用Javascript內(nèi)置的處理來驗證,反映到代碼里,就是看new Date(日期字符串)能否成功。在我的電腦中,輸入日期"9/5/2012"可以驗證通過,但“2012-9-5”驗證失敗,后者顯然也是一種正確的格式。我需要改變或者改善這種行為。如何做?

當然,我們可以修改jQuery Validation的源代碼,但是首先,我引用的是CDN上的代碼,其次,作為一個public的庫,我想還是盡量不要自己去改動,日久天長,可能我們已經(jīng)忘記了對它的修改,而官方更新新版本時,我們弄下來更新,結果就把我們自己的修改給覆蓋了。更好的辦法,是打補丁,從外部把date的驗證函數(shù)替換成我們自己的。這里或許要感謝Javascript的OO還不是那么徹底,并沒有把那些內(nèi)置驗證方法整成protected/private,看了源代碼之后,替換的方法很簡單,在引用jQuery Validation的源碼之后,再這樣替換:

復制代碼 代碼如下:

$.validator.methods.date = function (value, element)
{
// Date.parse函數(shù)源自另外一個處理日期的庫
return this.optional(element) || Date.parse(value) != null;
};

此外替換默認的message,也可以用同樣的辦法,比如:
復制代碼 代碼如下:

$.validator.messages.date = "hey, you entered an invalid date"

當然,處理messages有其他支持的更好的辦法,這在jQuery Validation的全球化和本地化的說明中有提及。

相關文章

  • jQuery的ajax下載blob文件

    jQuery的ajax下載blob文件

    這篇文章主要介紹了jQuery的ajax下載blob文件的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-07-07
  • jquery實現(xiàn)Ctrl+Enter提交表單的方法

    jquery實現(xiàn)Ctrl+Enter提交表單的方法

    這篇文章主要介紹了jquery實現(xiàn)Ctrl+Enter提交表單的方法,涉及jquery針對鍵盤按鍵的響應與表單操作相關技巧,非常簡單實用,需要的朋友可以參考下
    2015-07-07
  • jQuery前臺數(shù)據(jù)獲取實現(xiàn)代碼

    jQuery前臺數(shù)據(jù)獲取實現(xiàn)代碼

    jQuery前臺數(shù)據(jù)獲取實現(xiàn)代碼,需要的朋友可以參考下。
    2011-03-03
  • 兩種方法基于jQuery實現(xiàn)IE瀏覽器兼容placeholder效果

    兩種方法基于jQuery實現(xiàn)IE瀏覽器兼容placeholder效果

    這篇文章主要介紹了兩種方法基于jQuery實現(xiàn)IE瀏覽器兼容placeholder效果,需要的朋友可以參考下
    2014-10-10
  • Jquery使用Firefox FireBug插件調(diào)試Ajax步驟講解

    Jquery使用Firefox FireBug插件調(diào)試Ajax步驟講解

    本文介紹Jquery下的Ajax調(diào)試方法,Jquery Ajax 提供了全功能的 $.ajax() 方法,還有諸如 $.get(),$.getScript(),$.getJSON(),$.post() 和 $().load() 等更為簡便的方法
    2013-12-12
  • jQuery獲取訪問者IP地址的方法(基于新浪API與QQ查詢接口)

    jQuery獲取訪問者IP地址的方法(基于新浪API與QQ查詢接口)

    這篇文章主要介紹了jQuery獲取訪問者IP地址的方法,實例分析了jQuery基于新浪API與QQ查詢接口獲取來訪者IP的相關參數(shù)傳遞與數(shù)據(jù)處理技巧,需要的朋友可以參考下
    2016-05-05
  • 如何選擇jQuery版本 1.x? 2.x? 3.x?

    如何選擇jQuery版本 1.x? 2.x? 3.x?

    這篇文章主要給大家介紹了關于如何選擇jQuery版本,是1.x? 2.x?還是3.x? 在選擇使用jquery之前我們常常會考慮jQuery應該選擇什么版本?現(xiàn)在jquery一般用什么版本以及jquery ie8的兼容版本和jquery什么版本穩(wěn)定等問題,下面通過這篇文章來看看詳細的介紹吧。
    2017-04-04
  • jquery實現(xiàn)的動態(tài)回到頂部特效代碼

    jquery實現(xiàn)的動態(tài)回到頂部特效代碼

    這篇文章主要介紹了jquery實現(xiàn)的動態(tài)回到頂部特效代碼,涉及jQuery基于時間函數(shù)的定時遞歸調(diào)用實現(xiàn)帶緩沖效果的移動功能,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-10-10
  • Jquery zTree 樹控件異步加載操作

    Jquery zTree 樹控件異步加載操作

    這篇文章主要介紹了Jquery zTree 樹控件異步加載操作,學習Jquery zTree異步加載,zTree實現(xiàn)一套能完成大部分常用功能的 Tree插件,感興趣的小伙伴們可以參考一下
    2016-02-02
  • jQuery中DOM 屬性使用實例詳解上篇

    jQuery中DOM 屬性使用實例詳解上篇

    這篇文章主要為大家介紹了jQuery中DOM 屬性使用實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08

最新評論