執行ajax時什么情況會執行error的回調函數


 

 

$.ajax({  
    url : "/service/compute.ashx",  
    data : {  
        data: data  
    },  
    async: false,  
    dataType:"text",  
    success: function(data){  
         alert(data);  
    },  
    error: function(XMLHttpRequest, textStatus, errorThrown){  
         ShowMsg(XMLHttpRequest.readyState + XMLHttpRequest.status + XMLHttpRequest.responseText);
    }  
});  

首先ajax會執行error的可能原因有:
1. dataType錯誤(dataType用來指定后台返回參數的類型)

類型錯誤:后台返回的dataType類型和前台寫的不一致會跳入error。

格式錯誤:jquery1.4之后對json的格式要求非常嚴格,json格式錯誤也會跳入error.{“test”:1} 注意格式

有時,在不需要返回值的情況下,扔按模板格式,設置了dataType:”json”,參數;這時候,ajax傳值正確時,出現200返回成功狀態下報錯的特殊情況。

如果不指定,jQuery 將自動根據 HTTP 包 MIME 信息來智能判斷,比如 XML MIME 類型就被識別為 XML。在 1.4 中,JSON 就會生成一個 JavaScript 對象,而 script 則會執行這個腳本。隨后服務器端返回的數據會根據這個值解析后,傳遞給回調函數。可用值:
“xml”: 返回 XML 文檔,可用 jQuery 處理。
“html”: 返回純文本 HTML 信息;包含的 script 標簽會在插入 dom 時執行。
“script”: 返回純文本 JavaScript 代碼。不會自動緩存結果。除非設置了 “cache” 參數。注意:在遠程請求時(不在同一個域下),所有 POST 請求都將轉為 GET 請求。(因為將使用 DOM 的 script標簽來加載)
“json”: 返回 JSON 數據 。
“jsonp”: JSONP 格式。使用 JSONP 形式調用函數時,如 “myurl?callback=?” jQuery 將自動替換 ? 為正確的函數名,以執行回調函數。
“text”: 返回純文本字符串

async請求同步異步問題

async默認是true(異步請求),如果想一個Ajax執行完后再執行另一個Ajax, 需要把async=false

例如,你用post請求傳值到另一個頁面后台,但是頁面一加載你的ajax就已經執行過了,傳值接收是在后台才完成的,這時候就請求不到數據,所以可以考慮把ajax請求改為同步試試。

data不能不寫

data為空也一定要傳”{}”;不然返回的是xml格式的。並提示parsererror. data:”{}”

parsererror的異常和Header 類型也有關系。及編碼header(‘Content-type: text/html; charset=utf8’);

傳遞的參數

必須是ajax支持的編碼格式

URL路徑問題

路徑不能有中文

一般我們可以通過分析error中的一些參數進行錯誤原因的判斷:

XMLHttpRequest.readyState: 狀態碼

0 - (未初始化)還沒有調用send()方法
1 - (載入)已調用send()方法,正在發送請求
2 - (載入完成)send()方法執行完成,已經接收到全部響應內容
3 - (交互)正在解析響應內容
4 - (完成)響應內容解析完成,可以在客戶端調用了

XMLHttpRequest.status:調用http請求狀態
請求狀態有很多,具體遇到錯誤狀態代碼可以自行百度查詢。

XMLHttpRequest.responseText:返回的錯誤信息
如果發生了錯誤,錯誤信息(第二個參數)除了得到null之外,還可能是”timeout”, “error”, “notmodified” 和 “parsererror”。
 


免責聲明!

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



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