本文執行個體講述了jquery中ajax使用error調試錯誤的方法。分享給大家供大家參考。具體分析如下:
JQuery使我們在開發Ajax應用程式的時候提高了效率,減少了許多相容性問題,我們在Ajax項目中,遇到ajax非同步擷取資料出錯怎麼辦,我們可以通過捕捉error事件來擷取出錯的資訊。
jquery中ajax的常用用法類似於:
$(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函數文法為:
//請求成功後回呼函數。這個方法有兩個參數:伺服器返回資料,返回狀態 function (data, textStatus) { // data could be xmlDoc, jsonObj, html, text, etc... this; // the options for this ajax request }
當通過ajax非同步呼叫出錯時,會調用 error函數 。error函數文法為:
//(默 認: 自動判斷 (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');
希望本文所述對大家的jQuery程式設計有所協助。