1.情況描述:ajax發(fā)送成功,后臺也成功響應(yīng)請求,并返回了json數(shù)據(jù),通過chrome監(jiān)聽請求也可以看到響應(yīng)的json數(shù)據(jù),但是就是不進(jìn)success方法,反而跑到error方法中了
前端:
$.ajax({
type : "get",
data : {'dbId':node.dbId,'viewId':node.id,'date':new Date()},
url : "${ctp}/ViewOperate/ShowViewSql",
dataType : "json",
success : function(data){
console.log(data);
layer.alert(data,{
skin: 'layui-layer-molv'
});
}
error : function(data){
layer.alert("進(jìn)入了error方法",{
skin: 'layui-layer-molv'
});
}
});
后端:
@RequestMapping(value="/ShowViewSql",method=RequestMethod.GET)
@ResponseBody
public String showCreateViewSql(@RequestParam(value="dbId",required=false)Integer dbId,
@RequestParam(value="viewId",required=false)Integer viewId) {
return "abc";
}
原因:后臺返回的json數(shù)據(jù)是一個純String類型的對象時,前端dataType屬性設(shè)置為json后,會認(rèn)為這個由String對象轉(zhuǎn)換的json數(shù)據(jù)格式不是標(biāo)準(zhǔn)的json格式,所以就去執(zhí)行error對應(yīng)的方法了。
解決: 后端不用改,只需要把前端ajax請求中的dataType屬性設(shè)置為text即可
$.ajax({
type : "get",
data : {'dbId':node.dbId,'viewId':node.id,'date':new Date()},
url : "${ctp}/ViewOperate/ShowViewSql",
dataType : "text",
success : function(data){
console.log(data);
layer.alert(data,{
skin: 'layui-layer-molv'
});
}
error : function(data){
layer.alert("進(jìn)入了error方法",{
skin: 'layui-layer-molv'
});
}
});
特殊情況:當(dāng)后端返回的json數(shù)字是類似 “1”、”2”、”22”、”232123”、”-1”、 “232123.44” 數(shù)字字符串的時候,前端dataType屬性設(shè)置為json時,也能正常進(jìn)入success方法,原因不明。
以上這篇Ajax請求發(fā)送成功但不進(jìn)success的解決方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:- 解決ajax提交到后臺數(shù)據(jù)成功但返回不走success而走的error問題
- 解決ajax請求后臺,有時收不到返回值的問題
- 解決AJAX返回狀態(tài)200沒有調(diào)用success的問題