解決微信返回上一頁,頁面中的AJAX的請求,對Get請求無效的問題
先給大家分析問題產(chǎn)生原因
最近在做一個微信的項目時,遇到一種很常見的情況,需求是這樣的,當(dāng)用戶進入到“我的個人中心”的時候,會有一個點擊跳轉(zhuǎn)填寫認(rèn)證資料的按鈕,點擊此按鈕后,會跳轉(zhuǎn)到認(rèn)證資料填寫頁面,填寫資料,提交成功后。當(dāng)用戶直接返回到上一頁的時候。需要修改認(rèn)證狀態(tài)為“認(rèn)證中”。此時需要使用一個AJAX方法去查詢認(rèn)證狀態(tài),并修改頁面的狀態(tài)顯示。
當(dāng)時沒有按照標(biāo)準(zhǔn)的方法寫ajax方法,默認(rèn)使用的方法是Get請求,前臺JS代碼如下:
window.onload = function(){
var isProfesser=$('#isProfesser').val();
var isreview=$('#isreview').val();
var userid=$('#myId').val();
if(isProfesser=='0' && isreview=='0'){
$.ajax({
url:"/isAuthenticing",
data: {userid:userid},
success: function (data, textStatus, jqXHR) {
if(data.result=='1'){
$('#approveadd a').html("+認(rèn)證中")
}
},
error: function () {
}
});
}
//getMyQusetionInfo();
}
后臺controller默認(rèn)接收的也是GET
@RequestMapping(value = "/isAuthenticing", method = RequestMethod.GET)
@ResponseBody
public Map<String, Object> isAuthenticing(@RequestParam("userid") String userid,HttpServletRequest request) throws IOException {
//方法體;
}
解決辦法
實踐證明使用Get方法式是不行的,每次后退到上一頁的時候,頁面中的ajax方法會照常執(zhí)行,但是并不會請求后臺的controller,請求返回的值也是上一次加載頁面時候的值,具體原因我暫時不明確。
后來抱著試一試的心態(tài) 我使用可POST請求,出人意料的是 使用POST請求,真?zhèn)€流程就走通了。
前臺JS代碼如下:
window.onload = function(){
var isProfesser=$('#isProfesser').val();
var isreview=$('#isreview').val();
var userid=$('#myId').val();
if(isProfesser=='0' && isreview=='0'){
$.ajax({
url:"/isAuthenticing",
data: {userid:userid},
type: 'POST',
success: function (data, textStatus, jqXHR) {
if(data.result=='1'){
$('#approveadd a').html("+認(rèn)證中")
}
},
error: function () {
}
});
}
//getMyQusetionInfo();
}
后臺代碼:
@RequestMapping(value = "/isAuthenticing", method = RequestMethod.POST)
@ResponseBody
public Map<String, Object> isAuthenticing(@RequestParam("userid") String userid,HttpServletRequest request) throws IOException {
//方法體
}
希望能夠幫助那些和我遇到同樣問題的人。
注:紅色部分為修改的部分
以上所述是小編給大家介紹的解決微信返回上一頁,頁面中的AJAX的請求,對Get請求無效的問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Django框架利用ajax實現(xiàn)批量導(dǎo)入數(shù)據(jù)功能
這篇文章主要介紹了Django框架利用ajax實現(xiàn)批量導(dǎo)入數(shù)據(jù)功能的相關(guān)資料,需要的朋友可以參考下2016-03-03
Ajax標(biāo)簽導(dǎo)航效果(仿網(wǎng)易首頁)
Ajax標(biāo)簽導(dǎo)航效果(仿網(wǎng)易首頁)...2006-10-10
利用AJAX實現(xiàn)鼠標(biāo)懸浮獲取值的代碼
ajax實現(xiàn)將鼠標(biāo)放到圖標(biāo)上,下方會顯示和該圖有關(guān)的信息2009-12-12
基于Ajax和forms組件實現(xiàn)注冊功能的實例代碼
本文通過實例代碼給大家分享了基于Ajax和forms組件實現(xiàn)注冊功能,需要的朋友可以參考下2018-02-02
AJAX下的請求方式以及同步異步的區(qū)別小結(jié)
AJAX中的請求方式以及同步異步的區(qū)別小結(jié),學(xué)習(xí)ajax處理請求的朋友可以參考下。2010-08-08
利用 FormData 對象和 Spring MVC 配合實現(xiàn)Ajax文件下載功能
這篇文章主要介紹了利用 FormData 對象和 Spring MVC 配合實現(xiàn)Ajax文件下載功能,需要的朋友可以參考下2017-08-08

