php ajax sucess 失败,Ajax请求发送成功但不进success的解决方法(图文教程)
下面我就為大家分享一篇Ajax請求發送成功但不進success的解決方法,具有很好的參考價值,希望對大家有所幫助。
1.情況描述:ajax發送成功,后臺也成功響應請求,并返回了json數據,通過chrome監聽請求也可以看到響應的json數據,但是就是不進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("進入了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數據是一個純String類型的對象時,前端dataType屬性設置為json后,會認為這個由String對象轉換的json數據格式不是標準的json格式,所以就去執行error對應的方法了。
解決:后端不用改,只需要把前端ajax請求中的dataType屬性設置為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("進入了error方法",{
skin: 'layui-layer-molv'
});
}
});
特殊情況:當后端返回的json數字是類似 “1”、”2”、”22”、”232123”、”-1”、 “232123.44” 數字字符串的時候,前端dataType屬性設置為json時,也能正常進入success方法,原因不明。
上面是我整理給大家的,希望今后會對大家有幫助。
相關文章:
與50位技術專家面對面20年技術見證,附贈技術全景圖總結
以上是生活随笔為你收集整理的php ajax sucess 失败,Ajax请求发送成功但不进success的解决方法(图文教程)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: visa借记卡哪个银行办
- 下一篇: java mysql 死锁,java-S