jQuery AJAX timeout 超時問題詳解
先給大家分析下超時原因:
1.網(wǎng)絡(luò)不通暢。
2.后臺運行比較慢(服務(wù)器第一次運行時,容易出現(xiàn))
超時結(jié)果:JQ中 timeout設(shè)置請求超時時間。
如果服務(wù)器響應(yīng)時間超過了 設(shè)置的時間,則進(jìn)入 ERROR (錯誤處理)
超時解決方案:
1.默認(rèn)的timeout為0,代表永不超時
2.盡量把timeout設(shè)置的大一點。壞處:使數(shù)據(jù)的加載變慢(貌似。呵呵)。
3.在ERROR回調(diào)函數(shù)中寫 有關(guān)于 超時 處理 的函數(shù):例如,可以在超時的情況下再次調(diào)用取數(shù)據(jù)函數(shù)。
------------------------------------------------------- -------------------------------------------------------
這個ajax 里有個success的函數(shù). 是成功是返回的 還有個好像是叫error的返回函數(shù)
如果請求失敗的時候 會觸發(fā)這個函數(shù).
我覺得你可以在error里處理.
如果執(zhí)行了這個函數(shù)那你就調(diào)用你第二個ajax方法唄.
jQuery和ExtJS的timeOut超時設(shè)置和event事件處理 .
jQuery和ExtJS的timeOut超時設(shè)置和event事件處理 .
ajax請求如何自定義超時時間,并處理相應(yīng)的超時事件呢?
對jQuery 來說,超時可以直接設(shè)置timeout參數(shù),并在error事件中捕獲第二個參數(shù),如果是“timeout”則表明捕獲了超時事件,非常清楚。
例子:
$.ajax({ type: "POST" , contentType: "application/json" , url: "../ws/MyService.asmx/test" , data: '{"email":"' +email+'"}' , timeout: 30000, //超時時間:30秒 dataType: 'json' , error: function (XMLHttpRequest, textStatus, errorThrown){ //TODO: 處理status, http status code,超時 408 // 注意:如果發(fā)生了錯誤,錯誤信息(第二個參數(shù))除了得到null之外,還可能 //是"timeout", "error", "notmodified" 和 "parsererror"。 }, success: function (result) { // TODO: check result } });
另外,error事件返回的第一個參數(shù)XMLHttpRequest有一些有用的信息:
XMLHttpRequest.readyState: 狀態(tài)碼
0 - (未初始化)還沒有調(diào)用send()方法
1 - (載入)已調(diào)用send()方法,正在發(fā)送請求
2 - (載入完成)send()方法執(zhí)行完成,已經(jīng)接收到全部響應(yīng)內(nèi)容
3 - (交互)正在解析響應(yīng)內(nèi)容
4 - (完成)響應(yīng)內(nèi)容解析完成,可以在客戶端調(diào)用了
XMLHttpRequest.status屬性:一些錯誤代碼
HTTP
1xx-信息提示
這些狀態(tài)代碼表示臨時的響應(yīng)??蛻舳嗽谑盏匠R?guī)響應(yīng)之前,應(yīng)準(zhǔn)備接收一個或多個1xx響應(yīng)。
100-繼續(xù)。
101-切換協(xié)議。
2xx-成功
這類狀態(tài)代碼表明服務(wù)器成功地接受了客戶端請求。
200-確定??蛻舳苏埱笠殉晒?。
201-已創(chuàng)建。
202-已接受。
203-非權(quán)威性信息。
204-無內(nèi)容。
205-重置內(nèi)容。
206-部分內(nèi)容。
3xx-重定向
客戶端瀏覽器必須采取更多操作來實現(xiàn)請求。例如,瀏覽器可能不得不請求服務(wù)器上的不同的頁面,或通過代理服務(wù)器重復(fù)該請求。
301-對象已永久移走,即永久重定向。
302-對象已臨時移動。
304-未修改。
307-臨時重定向。
4xx-客戶端錯誤
發(fā)生錯誤,客戶端似乎有問題。例如,客戶端請求不存在的頁面,客戶端未提供有效的身份驗證信息。400-錯誤的請求。
401-訪問被拒絕。IIS定義了許多不同的401錯誤,它們指明更為具體的錯誤原因。這些具體的錯誤代碼在瀏覽器中顯示,但不在IIS日志中顯示:
401.1-登錄失敗。
401.2-服務(wù)器配置導(dǎo)致登錄失敗。
401.3-由于ACL對資源的限制而未獲得授權(quán)。
401.4-篩選器授權(quán)失敗。
401.5-ISAPI/CGI應(yīng)用程序授權(quán)失敗。
401.7–訪問被Web服務(wù)器上的URL授權(quán)策略拒絕。這個錯誤代碼為IIS6.0所專用。
403-禁止訪問:IIS定義了許多不同的403錯誤,它們指明更為具體的錯誤原因:
403.1-執(zhí)行訪問被禁止。
403.2-讀訪問被禁止。
403.3-寫訪問被禁止。
403.4-要求SSL。
403.5-要求SSL128。
403.6-IP地址被拒絕。
403.7-要求客戶端證書。
403.8-站點訪問被拒絕。
403.9-用戶數(shù)過多。
403.10-配置無效。
403.11-密碼更改。
403.12-拒絕訪問映射表。
403.13-客戶端證書被吊銷。
403.14-拒絕目錄列表。
403.15-超出客戶端訪問許可。
403.16-客戶端證書不受信任或無效。
403.17-客戶端證書已過期或尚未生效。
403.18-在當(dāng)前的應(yīng)用程序池中不能執(zhí)行所請求的URL。這個錯誤代碼為IIS6.0所專用。
403.19-不能為這個應(yīng)用程序池中的客戶端執(zhí)行CGI。這個錯誤代碼為IIS6.0所專用。
403.20-Passport登錄失敗。這個錯誤代碼為IIS6.0所專用。
404-未找到。
404.0-(無)–沒有找到文件或目錄。
404.1-無法在所請求的端口上訪問Web站點。
404.2-Web服務(wù)擴展鎖定策略阻止本請求。
404.3-MIME映射策略阻止本請求。
405-用來訪問本頁面的HTTP謂詞不被允許(方法不被允許)
406-客戶端瀏覽器不接受所請求頁面的MIME類型。
407-要求進(jìn)行代理身份驗證。
412-前提條件失敗。
413–請求實體太大。
414-請求URI太長。
415–不支持的媒體類型。
416–所請求的范圍無法滿足。
417–執(zhí)行失敗。
423–鎖定的錯誤。
5xx-服務(wù)器錯誤
服務(wù)器由于遇到錯誤而不能完成該請求。
500-內(nèi)部服務(wù)器錯誤。
500.12-應(yīng)用程序正忙于在Web服務(wù)器上重新啟動。
500.13-Web服務(wù)器太忙。
500.15-不允許直接請求Global.asa。
500.16–UNC授權(quán)憑據(jù)不正確。這個錯誤代碼為IIS6.0所專用。
500.18–URL授權(quán)存儲不能打開。這個錯誤代碼為IIS6.0所專用。
500.100-內(nèi)部ASP錯誤。
501-頁眉值指定了未實現(xiàn)的配置。
502-Web服務(wù)器用作網(wǎng)關(guān)或代理服務(wù)器時收到了無效響應(yīng)。
502.1-CGI應(yīng)用程序超時。
502.2-CGI應(yīng)用程序出錯。application.
503-服務(wù)不可用。這個錯誤代碼為IIS6.0所專用。
504-網(wǎng)關(guān)超時。
505-HTTP版本不受支持。
FTP
1xx-肯定的初步答復(fù)
這些狀態(tài)代碼指示一項操作已經(jīng)成功開始,但客戶端希望在繼續(xù)操作新命令前得到另一個答復(fù)。
110重新啟動標(biāo)記答復(fù)。
120服務(wù)已就緒,在nnn分鐘后開始。
125數(shù)據(jù)連接已打開,正在開始傳輸。
150文件狀態(tài)正常,準(zhǔn)備打開數(shù)據(jù)連接。
2xx-肯定的完成答復(fù)
一項操作已經(jīng)成功完成??蛻舳丝梢詧?zhí)行新命令。200命令確定。
202未執(zhí)行命令,站點上的命令過多。
211系統(tǒng)狀態(tài),或系統(tǒng)幫助答復(fù)。
212目錄狀態(tài)。
213文件狀態(tài)。
214幫助消息。
215NAME系統(tǒng)類型,其中,NAME是AssignedNumbers文檔中所列的正式系統(tǒng)名稱。
220服務(wù)就緒,可以執(zhí)行新用戶的請求。
221服務(wù)關(guān)閉控制連接。如果適當(dāng),請注銷。
225數(shù)據(jù)連接打開,沒有進(jìn)行中的傳輸。
226關(guān)閉數(shù)據(jù)連接。請求的文件操作已成功(例如,傳輸文件或放棄文件)。
227進(jìn)入被動模式(h1,h2,h3,h4,p1,p2)。
230用戶已登錄,繼續(xù)進(jìn)行。
250請求的文件操作正確,已完成。
257已創(chuàng)建“PATHNAME”。
3xx-肯定的中間答復(fù)
該命令已成功,但服務(wù)器需要更多來自客戶端的信息以完成對請求的處理。331用戶名正確,需要密碼。
332需要登錄帳戶。
350請求的文件操作正在等待進(jìn)一步的信息。
4xx-瞬態(tài)否定的完成答復(fù)
該命令不成功,但錯誤是暫時的。如果客戶端重試命令,可能會執(zhí)行成功。421服務(wù)不可用,正在關(guān)閉控制連接。如果服務(wù)確定它必須關(guān)閉,將向任何命令發(fā)送這一應(yīng)答。
425無法打開數(shù)據(jù)連接。
426Connectionclosed;transferaborted.
450未執(zhí)行請求的文件操作。文件不可用(例如,文件繁忙)。
451請求的操作異常終止:正在處理本地錯誤。
452未執(zhí)行請求的操作。系統(tǒng)存儲空間不夠。
5xx-永久性否定的完成答復(fù)
該命令不成功,錯誤是永久性的。如果客戶端重試命令,將再次出現(xiàn)同樣的錯誤。500語法錯誤,命令無法識別。這可能包括諸如命令行太長之類的錯誤。
501在參數(shù)中有語法錯誤。
502未執(zhí)行命令。
503錯誤的命令序列。
504未執(zhí)行該參數(shù)的命令。
530未登錄。
532存儲文件需要帳戶。
550未執(zhí)行請求的操作。文件不可用(例如,未找到文件,沒有訪問權(quán)限)。
551請求的操作異常終止:未知的頁面類型。
552請求的文件操作異常終止:超出存儲分配(對于當(dāng)前目錄或數(shù)據(jù)集)。
553未執(zhí)行請求的操作。不允許的文件名。
常見的FTP狀態(tài)代碼及其原因
150-FTP使用兩個端口:21用于發(fā)送命令,20用于發(fā)送數(shù)據(jù)。狀態(tài)代碼150表示服務(wù)器準(zhǔn)備在端口20上打開新連接,發(fā)送一些數(shù)據(jù)。
226-命令在端口20上打開數(shù)據(jù)連接以執(zhí)行操作,如傳輸文件。該操作成功完成,數(shù)據(jù)連接已關(guān)閉。
230-客戶端發(fā)送正確的密碼后,顯示該狀態(tài)代碼。它表示用戶已成功登錄。
331-客戶端發(fā)送用戶名后,顯示該狀態(tài)代碼。無論所提供的用戶名是否為系統(tǒng)中的有效帳戶,都將顯示該狀態(tài)代碼。
426-命令打開數(shù)據(jù)連接以執(zhí)行操作,但該操作已被取消,數(shù)據(jù)連接已關(guān)閉。
530-該狀態(tài)代碼表示用戶無法登錄,因為用戶名和密碼組合無效。如果使用某個用戶帳戶登錄,可能鍵入錯誤的用戶名或密碼,也可能選擇只允許匿名訪問。如果使用匿名帳戶登錄,IIS的配置可能拒絕匿名訪問。
550-命令未被執(zhí)行,因為指定的文件不可用。例如,要GET的文件并不存在,或試圖將文件PUT到您沒有寫入權(quán)限的目錄。
ExtJS 的默認(rèn)超時時間是30s,超過就會ajax請求失敗,http status code 408。
設(shè)置ExtJS的超時時間方法需要用Ext.data.Connection 對象,并捕捉requestexception事件,例子:
var conn=new Ext.data.Connection({ url: "../ws/MyService.asmx/test" , timeout : 60000, //自定義超時時間,這里是60秒 (默認(rèn)30s) autoAbort : false , disableCaching : true , method : "GET" }); var proxy = new Ext.data.HttpProxy(conn); proxy.getConnection().on("requestcomplete" , function (sender, response, options){ //成功,response.status = 200, response.statusText = 'OK' }); proxy.getConnection().on("requestexception" , function (sender, response, options){ //異常,捕捉 esponse.status ( http status code 代碼 )和 response.statusText }); var store = new Ext.data.Store({ proxy: proxy, reader: myReader, //需要另外定義一個reader baseParams: {myargument:'myargumentValue' }, //改成你的參數(shù)名和值 remoteSort: false }); store.load();
以上所述是小編給大家介紹的jQuery AJAX timeout 超時問題詳解的相關(guān)知識,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
jquer之a(chǎn)jaxQueue簡單實現(xiàn)代碼
手頭不是很忙,突然想到了ajax queue這個概念,之前貌似有看技術(shù)文章中提到過這個,就想著用jquery來實現(xiàn)一下,思想比較簡單2011-09-09jQuery插件HighCharts實現(xiàn)的2D條狀圖效果示例【附demo源碼下載】
這篇文章主要介紹了jQuery插件HighCharts實現(xiàn)的2D條狀圖效果,結(jié)合完整實例形式詳細(xì)分析了jQuery插件HighCharts繪制2D條狀圖的操作步驟與相關(guān)屬性設(shè)置技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03Jquery 基礎(chǔ)學(xué)習(xí)筆記之文檔處理
本節(jié)讓我們繼續(xù)Jquery知識的了解:文檔處理。文檔處理主要是對HTML元素進(jìn)行一些增操作,刪除操作,復(fù)制操作,替換操作。2009-05-05jQuery.autocomplete 支持中文輸入(firefox)修正方法
jQuery.autocomplete 是jquery的流行插件,,能夠很好的實現(xiàn)輸入框的自動完成(autocomplete)、建議提示(input suggest)功能,支持ajax數(shù)據(jù)加載。2011-03-03