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

首頁 > 編程 > JavaScript > 正文

Jquery validation remote 驗證的緩存問題解決方法

2019-11-20 20:54:37
字體:
來源:轉載
供稿:網友
最近項目中一直在用 Jquery validation 做校驗,結合bootstrap 和 jquery form 感覺效果不錯。但是remote驗證的緩存問題讓我頭痛了很久,幾乎就像放棄這款插件了。

舉例說明:

現有學校,年級,班級實體

在同一學校下不能有相同的年級,在同一年級下不能有相同的班級

以同一學校下不能有相同年級為例,在驗證的時候用remote方式:

JS
復制代碼 代碼如下:

"gradeId" : {
required : true,
min : 0,
remote: {
url: "gradeManager-checkGrade.action",
type: "post",
dataType: "json",
data: {
'gradeId' : function() {
return $("#gradeId").val();
},
'schoolId' : function() {
return $("#schoolId").val();
}
}
}
}

HTML
復制代碼 代碼如下:

<div class="control-group">
<label class="control-label" for="schoolId">學校</label>
<div class="controls">
<s:select name="schoolId" list="schools" listKey="schoolId"
listValue="schoolName" headerKey="-1" headerValue="請選擇學校"></s:select>
</div>
</div>

<div class="control-group">
<label class="control-label" for="gradeId">年級</label>
<div class="controls">
<s:select name="gradeId" list="grades" listKey="gradeId"
listValue="gradeName" headerKey="-1" headerValue="請選擇年級"></s:select>
</div>
</div>

現在有 測試學校1、測試學校2,兩所學校,其中測試學校1下有 小學一年級、小學二年級兩個年級

理論上,在新增年級的時候,如果學校選擇測試學校1,那么選擇小學一年級、小學二年級時remote驗證會報錯“該年級已經存在”

事實上,第一次操作時,結果也是正確的
 
但是如果此時再更改學校,比如選擇測試學校2,由于緩存問題,validation插件并不會重新進行新的remote驗證而會直接返回上一次驗證的結果,于是就有了如下蛋疼的錯誤
 
這還不是最難讓人接受的,更嚴重的問題時如果先選擇了測試學校2、和小學一年級,remote驗證通過,此時再選擇測試學校1,remote驗證依然通過,如此一來同一學校下不能有相同年級的驗證就等于失敗了


于是進行了各種查詢解決方法

有種說法是,在remote中加入 "cache: false",但是實測并沒有解決問題

嘗試過在學校下拉框上綁定onchange事件清空gradeId的值,依然無法解決問題

查閱了validation的api,發現 .valid() 方法可以主動觸發驗證,但是由于緩存問題,remote依然沒有重新驗證

還查看了validation的源碼,發現其中有個previousValue這個東西,如果有值就會直接return 前一次的驗證結果
 
于是嘗試了一下清空這個值
復制代碼 代碼如下:

$("#schoolId").change(function(){
$("#gradeId").removeData("previousValue");
});

成功解決問題
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩精品中文字幕久久臀| 欧洲精品在线视频| 久久久精品国产一区二区| 久久久成人的性感天堂| 久久视频这里只有精品| 欧美日韩国产第一页| 日韩的一区二区| 亚洲国产精品久久久久秋霞蜜臀| 日韩精品极品在线观看播放免费视频| 日韩国产在线播放| 欧美大片免费观看在线观看网站推荐| 欧美在线视频观看免费网站| 亚洲欧洲在线播放| 久久综合免费视频影院| 国产日韩欧美夫妻视频在线观看| 亚洲欧美日韩在线高清直播| 精品国产网站地址| 91av在线不卡| 国产91|九色| 国产91在线视频| 91老司机精品视频| 欧美性精品220| 欧美资源在线观看| 亚洲第一福利在线观看| 久久精品一本久久99精品| 久久久精品视频成人| 国产一区二区三区中文| 国产精品高潮在线| 国产成人精品在线观看| 精品成人乱色一区二区| 日本人成精品视频在线| 久久久极品av| 91久久精品国产91久久性色| 国产精品91视频| 91精品国产91久久久久久不卡| 亚洲天堂成人在线视频| 久久久爽爽爽美女图片| 欧美性受xxxx黑人猛交| 欧美壮男野外gaytube| 欧美巨乳美女视频| 亚洲成人免费在线视频| 51久久精品夜色国产麻豆| 高清在线视频日韩欧美| 日韩亚洲在线观看| 欧美片一区二区三区| 久久久久国产精品免费| 亚洲自拍小视频免费观看| 欧美最近摘花xxxx摘花| 91精品久久久久久久久| 亚洲高清免费观看高清完整版| 亚洲大胆美女视频| 日韩精品欧美国产精品忘忧草| 久久久久久中文| 国产欧美在线播放| 欧美理论在线观看| 欧美日本啪啪无遮挡网站| 成人激情视频在线观看| 亚洲xxxx视频| 成人黄色av网| 伊人久久男人天堂| 97人人爽人人喊人人模波多| 亚洲老头同性xxxxx| 91在线高清视频| 中文字幕日韩专区| 欧美一乱一性一交一视频| 亚洲性猛交xxxxwww| 97精品国产97久久久久久免费| 免费91在线视频| 国产精品福利在线| 国产欧美精品xxxx另类| 国产精品专区一| 久久深夜福利免费观看| 精品毛片三在线观看| 精品中文视频在线| 欧美成人一二三| 91色琪琪电影亚洲精品久久| 久久久久久九九九| 国产一区红桃视频| 国产香蕉精品视频一区二区三区| 伊人久久久久久久久久| 日韩精品极品视频| 国产中文字幕日韩| 久久人体大胆视频| 久久精品国产久精国产一老狼| 亚洲福利在线看| 精品动漫一区二区| 日韩免费不卡av| 日韩精品高清在线观看| 中文字幕欧美专区| 亚洲男人第一av网站| 欧美日韩加勒比精品一区| 久久久成人的性感天堂| 中文日韩在线观看| 国产成人午夜视频网址| 欧美性猛交xxxx乱大交极品| 在线成人免费网站| 欧美wwwwww| 成人免费观看网址| 亚洲国产古装精品网站| 日本精品中文字幕| 久久精品电影一区二区| 亚洲视频视频在线| 欧美大片欧美激情性色a∨久久| 隔壁老王国产在线精品| 热久久视久久精品18亚洲精品| 国产精品777| 亚洲精品视频免费| 不卡伊人av在线播放| 国语自产偷拍精品视频偷| 成人在线免费观看视视频| 国产一区二区三区在线观看视频| 久久中文字幕在线| 亚洲欧美中文字幕在线一区| 91高清免费视频| 国产精品扒开腿做| 欧美日韩国产一区中文午夜| 国产精品jizz在线观看麻豆| 97人人做人人爱| 欧美在线xxx| 91精品国产综合久久香蕉最新版| 欧美激情一区二区久久久| 亚洲欧美日韩天堂| 97视频在线免费观看| 日韩av不卡在线| 亚洲精品电影网在线观看| 一区二区三欧美| 欧美理论在线观看| 日韩视频免费观看| 欧美诱惑福利视频| 久久久精品一区二区| 91精品久久久久久久久久入口| 欧美激情综合亚洲一二区| 神马久久久久久| 日本一欧美一欧美一亚洲视频| 久久精品国产精品亚洲| 国产一区二区三区网站| 亚洲欧美日韩区| 精品国产91久久久久久| 久久精品国产欧美亚洲人人爽| 精品久久久国产精品999| 国产91av在线| 日韩av最新在线观看| 日本午夜人人精品| 国产精品丝袜白浆摸在线| 亚洲精品免费av| 欧美午夜性色大片在线观看| 日韩经典中文字幕| 成人h视频在线观看播放| 日韩久久精品成人| 亚洲精品日韩久久久| 日韩在线欧美在线| 一区二区三区无码高清视频| 在线播放精品一区二区三区| 国产一区二区三区在线| 欧洲成人免费aa| 91麻豆国产语对白在线观看| 都市激情亚洲色图| 久久99青青精品免费观看| 91手机视频在线观看| 91精品国产九九九久久久亚洲| 日韩欧美在线网址| 欧美日韩裸体免费视频| 成人激情黄色网| 爽爽爽爽爽爽爽成人免费观看|