DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> jQuery入門知識 >> JQuery入門技巧 >> jQuery通過ajax方法獲取json數據不執行success的原因及解決方法
jQuery通過ajax方法獲取json數據不執行success的原因及解決方法
編輯:JQuery入門技巧     

1.jquery通過ajax方法獲取json數據不執行success回調

問題描述:jquery通過ajax方法獲取json數據不執行success回調方法

問題原因:json格式存在問題或不符合標准寫法,導致總是執行error回調方法

解決方案:使json格式務必符合下述3個標准寫法:

    1)鍵名稱:用雙引號括起;

    2)字符串:用雙引號括起;

    3)數字,布爾值不需要使用雙引號括起 ;

注意:一定是雙括號!

2.jQuery中ajax使用json數據類型總是跳過success執行error語句

執行函數

error : function(XMLHttpRequest, textStatus, errorThrown) {
//這個error函數調試時非常有用,如果解析不正確,將會彈出錯誤框
    alert(XMLHttpRequest.responseText); 
alert(XMLHttpRequest.status);
alert(XMLHttpRequest.readyState);
alert(textStatus); // parser error;
}

就明白錯誤信息了;

彈出的框裡顯示:

<!DOCTYPE html PUBLIC "-//W3C //DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD /xhtml1-transitional.dtd">以 及<?xml version="1.0" encoding="gb2312" ?>

這兩句話,雖然不清楚為什麼,我刪除之後,就成功執行 success了

3.$.ajax()中的URL跨域時,總是不執行success,老進入error

1)我加上ServletActionContext.getResponse().setHeader("Access-Control-Allow-Origin", "*");

解決跨域問題,就順利進入success了

2)dataType:"json",

去掉 看能進success 不 。

dataType 是預期服務器返回過來的信息類型 。

原因:返回的數據類型一定要符合定義的數據類型。即如果你定義的 dataType 是 json 類型的,那麼返回來的數據一定是 json 才可以,平且不然就會執行 error 裡的程序塊兒。

(1) 同時需要特別的注意返回的JSON數據是否是嚴格的JSON格式.

(2) 也應該嚴重關切當後台返回的是一個List 數據(List當中的數據是Json格式)時,有沒髒數據即不是嚴格的JSON格式。

以上所述是小編給大家介紹的jQuery通過ajax方法獲取json數據不執行success的原因及解決方法,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的,在此也非常感謝大家對網站的支持!

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved