Jquery validation remote 驗證的快取問題解決方法_jquery
快取
驗證
最近專案中一直在用 Jquery validation 做校驗,結合bootstrap 和 jquery form 感覺效果不錯。但remote驗證的快取問題讓我頭痛了很久,幾乎就像放棄這款外掛了。
舉例說明:
現有學校,年級,班級實體
在同一學校下不能有相同的年級,在同一年級下不能有相同的班級
以同一學校下不能有相同年級為例,在驗證的時候用remote方式:
JS
複製代碼 程式碼如下:
"gradeId" : {
required : true,
min : 0,
remote: {
Manager -checkGrade.action",
type: "post",
dataType: "json",
data: {
'gradeId' : function() {
return $("#gradeId ").val();
},
'schoolId' : function() {
return $("#schoolId").val();
}
}
}
}
HTML
複製程式碼 程式碼:
複製程式碼程式碼:
現在有測試學校1、測試學校2,兩所學校,其中測試學校1下有小學一年級、小學二年級兩個年級
理論上,在新增年級的時候,如果學校選擇測試學校1,那麼選擇小學一年級、小學二年級時remote驗證會報錯「該年級已經存在」


這還不是最難讓人接受的,更嚴重的問題時如果先選擇了測試學校2、和小學一年級,remote驗證通過,此時再選擇測試學校1,remote驗證依然通過,如此一來同一學校下不能有相同年級的驗證就等於失敗了
於是進行了各種查詢解決方法
有種說法是,在remote中加入"cache: false",但是實測並沒有解決問題
嘗試過在學校下拉框上綁定onchange事件清空gradeId的值,依然無法解決問題
查閱了validation的api,發現.valid() 方法可以主動觸發驗證,但是由於緩存問題,remote依然沒有重新驗證

程式碼如下:
$("#schoolId") .change(function(){
$("#gradeId").removeData("previousValue");
}); $("#schoolId") .change(function(){
$("#gradeId").removeData("previousValue");
成功解決問題
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前
By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
R.E.P.O.保存文件位置:在哪里以及如何保護它?
3 週前
By DDD

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)