国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

Jquery validation remote 驗(yàn)證的緩存問題解決方法

2024-05-06 16:03:13
字體:
供稿:網(wǎng)友
這篇文章主要介紹了Jquery validation remote 驗(yàn)證的緩存問題的解決方法 ,需要的朋友可以參考下

最近項(xiàng)目中一直在用 Jquery validation 做校驗(yàn),結(jié)合bootstrap 和 jquery form 感覺效果不錯(cuò)。但是remote驗(yàn)證的緩存問題讓我頭痛了很久,幾乎就像放棄這款插件了。

舉例說明:

現(xiàn)有學(xué)校,年級,班級實(shí)體

在同一學(xué)校下不能有相同的年級,在同一年級下不能有相同的班級

以同一學(xué)校下不能有相同年級為例,在驗(yàn)證的時(shí)候用remote方式:

JS

復(fù)制代碼 代碼如下:


"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

復(fù)制代碼 代碼如下:


<div>
<label for="schoolId">學(xué)校</label>
<div>
<s:select list="schools" listKey="schoolId"
listValue="schoolName" headerKey="-1" headerValue="請選擇學(xué)校"></s:select>
</div>
</div>

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


現(xiàn)在有 測試學(xué)校1、測試學(xué)校2,兩所學(xué)校,其中測試學(xué)校1下有 小學(xué)一年級、小學(xué)二年級兩個(gè)年級

理論上,在新增年級的時(shí)候,如果學(xué)校選擇測試學(xué)校1,那么選擇小學(xué)一年級、小學(xué)二年級時(shí)remote驗(yàn)證會(huì)報(bào)錯(cuò)“該年級已經(jīng)存在”

事實(shí)上,第一次操作時(shí),結(jié)果也是正確的

Jquery validation remote 驗(yàn)證的緩存問題解決方法

 
但是如果此時(shí)再更改學(xué)校,比如選擇測試學(xué)校2,由于緩存問題,validation插件并不會(huì)重新進(jìn)行新的remote驗(yàn)證而會(huì)直接返回上一次驗(yàn)證的結(jié)果,于是就有了如下蛋疼的錯(cuò)誤

Jquery validation remote 驗(yàn)證的緩存問題解決方法

 
這還不是最難讓人接受的,更嚴(yán)重的問題時(shí)如果先選擇了測試學(xué)校2、和小學(xué)一年級,remote驗(yàn)證通過,此時(shí)再選擇測試學(xué)校1,remote驗(yàn)證依然通過,如此一來同一學(xué)校下不能有相同年級的驗(yàn)證就等于失敗了


于是進(jìn)行了各種查詢解決方法

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

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

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

還查看了validation的源碼,發(fā)現(xiàn)其中有個(gè)previousValue這個(gè)東西,如果有值就會(huì)直接return 前一次的驗(yàn)證結(jié)果

Jquery validation remote 驗(yàn)證的緩存問題解決方法

 
于是嘗試了一下清空這個(gè)值

復(fù)制代碼 代碼如下:


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


成功解決問題
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 张家界市| 明溪县| 汤原县| 德庆县| 甘孜| 海淀区| 葫芦岛市| 桦甸市| 双城市| 安康市| 肥东县| 洛浦县| 永川市| 馆陶县| 临城县| 白城市| 长岭县| 涿州市| 得荣县| 泸州市| 仙桃市| 成武县| 全椒县| 疏附县| 双流县| 庐江县| 宁陕县| 德保县| 大安市| 嘉鱼县| 西吉县| 察雅县| 磴口县| 益阳市| 五莲县| 安顺市| 富阳市| 岳西县| 永昌县| 涪陵区| 九龙城区|