ajax請求返回null不走success


1.情況描述:ajax發送成功,后台也成功響應請求,並返回了json數據,通過chrome監聽請求也可以看到響應的json數據,但是就是不進success方法,反而跑到error方法中了

前端:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
$.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'
    });
  }
});

后端:

1
2
3
4
5
6
@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即可

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
$.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的解決方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

 

轉自:https://www.jb51.net/article/133174.htm


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM