1. 程式人生 > >jquery中ajax使用error除錯錯誤的方法

jquery中ajax使用error除錯錯誤的方法

JQuery使我們在開發Ajax應用程式的時候提高了效率,減少了許多相容性問題,我們在Ajax專案中,遇到ajax非同步獲取資料出錯怎麼辦,我們可以通過捕捉error事件來獲取出錯的資訊。

jquery中ajax的常用用法類似於:

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 $(document).ready( function () {    jQuery( "#clearCac" ).click( function () {   jQuery.ajax({    
url: url,     type: "post" ,     data: { id: '0' },     dataType: "json" ,
    success: function (msg) {   alert(msg);     },     error: function (XMLHttpRequest, textStatus, errorThrown) {   alert(XMLHttpRequest.status);   alert(XMLHttpRequest.readyState);   alert(textStatus);     },     complete: function (XMLHttpRequest, textStatus) {   this ; // 呼叫本次AJAX請求時傳遞的options引數     }   });    }); });

當通過ajax非同步呼叫成功時,會呼叫 success函式 。success函式語法為:

?
1 2 3 4 5 6 7 //請求成功後回撥函式。這個方法有兩個引數:伺服器返回資料,返回狀態 function (data, textStatus) {   // data could be xmlDoc, jsonObj, html, text, etc...      this ; // the options for this ajax request }

當通過ajax非同步調用出錯時,會呼叫 error函式 。error函式語法為:

?
1 2 3 4 5 6 7 8 9 10 11 //(默 認: 自動判斷 (xml 或 html)) 請求失敗時呼叫時間。 //引數有以下三個:XMLHttpRequest 物件、錯誤資訊、(可選)捕獲的錯誤物件。 //如果發生了錯誤,錯誤資訊(第二個引數)除了得到null之外, //還可能是"timeout", "error", "notmodified" 和 "parsererror"。     //textStatus: "timeout", "error", "notmodified" 和 "parsererror"。    error: function (XMLHttpRequest, textStatus, errorThrown)      }

error事件返回的第一個引數XMLHttpRequest:
XMLHttpRequest.readyState: 狀態碼的意思
0 - (未初始化)還沒有呼叫send()方法
1 - (載入)已呼叫send()方法,正在傳送請求
2 - (載入完成)send()方法執行完成,已經接收到全部響應內容
3 - (互動)正在解析響應內容
4 - (完成)響應內容解析完成,可以在客戶端呼叫了
 
傳送error可能有下面兩張引起的,或者其他程式問題,需要我們認真仔細。
1、data:"{}", data為空也一定要傳"{}";不然返回的是xml格式的。並提示parsererror.
2、parsererror的異常和Header 型別也有關係。及編碼header('Content-type: text/html; charset=utf8');