DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> jQuery入門知識 >> JQuery特效代碼 >> jquery validate在ie8下的bug解決方法
jquery validate在ie8下的bug解決方法
編輯:JQuery特效代碼     
項目用到了jquery的表單校驗插件validate,之前一直都只是做很簡單的校驗,沒有做過稍微復雜的應用,近期項目對應用的要求提高了,一個頁面中有兩個提交按鈕,然後表單校驗是綁定在按鈕的點擊事件上的,如下。
 
然後很自然的就用到了插件的valid()函數:
 
這個確實能達到相要的效果,但是在ie8下竟然有問題,valid()方法始終返回false,而且所有的字段都會被當成必填字段校驗,糾結了好久,因為jquery的插件代碼都很復雜,所以剛開始看特別費勁,後來一步一步排查,找到問題了,問題出在attributeRules()函數上:
 
這個函數的作用是:當你把校驗規則寫在頁面上而不是腳本裡面時,同樣可以應用校驗框架。技術上是很合理的,對required的處理也是合理的,但是對於ie8來說,就有點問題了。ie8會執行以下分支:
 
所以,所有的字段都會被當成必填字段校驗了。經過測試,最後又兩種方法可以解決:

第一種是在rules()方法裡面找到下面這段代碼,注釋掉對attributeRules()的調用,之所以可以這樣做,是因為一般很少會把校驗寫到頁面中去,當然這個肯定不是最佳解決方案,那就看看第二種。
 
第二種解決方法需要做兩件事情:首先,需要對attributeRules()方法做一些修改,把getAttribute()方法換成attr()方法。注意getAttribute()是js方法,而attr()是jquery方法,它們的使用對象是不一樣的,其實這樣改完後,ie8下面的bug已經解決了,但是ie7下又出現了這種問題,所以你要用最新的jquery,我測試的時候用的是jquery1.10.2版本。
 
哦,對了,最後不要忘記阻止表單的默認事件。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved