Ajax請求發送成功但不進success如何解決

小云云
發布: 2023-03-19 15:20:01
原創
3103 人瀏覽過

本文主要為大家分享一篇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方法,原因不明。

相關推薦:

淺析Ajax後台success傳來json資料的問題

ThinkPHP頁面跳轉success與error方法概述_PHP教學

jQuery.ajax中success 和complete 區別

#

以上是Ajax請求發送成功但不進success如何解決的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!