永利赌盘网投赌场

2019-11-02JavaScript5460
  • 詳情內容
  • 留言點評

前端發送Ajax請求到服務器,服務器返回數據這一過程,因原因不同耗時長短也有差別,且這段時間內頁面顯示空白。如何優化這段時間內的交互體驗,以及長時間內服務器仍未返回數據這一問題,是我們開發中不容忽視的重點。

常見的做法是︰

1、設置超時時間,一旦時間超過設定值,便終止請求;
2、頁面內容加載之前,手動增加一個 loading 層。

下面是幾則示例代碼︰

getAjax: function (method, apiUrl, options, callback) { var xhr = $.ajax({  type: method,  url: apiUrl,  data: options,  timeout: 5000,  // 設置超時時間  dataType: "json",  beforeSend: function (xhr) {  $.showLoading(); // 數據加載成功之前,使用loading組件  },  success: function(json) {  $.hideLoading(); // 成功後,隱藏loading組件  if(callback && callback instanceof Function === "true") {   callback(json);  }  },  error: function (textStatus) {  console.error(textStatus);  },  complete: function (XMLHttpRequest,status) {  if(status == 'timeout') {   xhr.abort(); // 超時後中斷請求   $.alert("網絡超時,請刷新", function () {   location.reload();   })  }  } }) }
$.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// 注意︰如果發生了錯誤,錯誤信息(第二個參數)除了得到null之外,還可能//是"timeout", "error", "notmodified" 和 "parsererror"。},success: function(result) {// TODO: check result}});
function load(){ $("#tips").html("加載中..."); $.ajax({  async:true,  cache:false,  timeout:8000,  type:"POST",  url:"result.php",  data:{a:'123'},  error:function(jqXHR, textStatus, errorThrown){  if(textStatus=="timeout"){  $("#tips").html("加載超時,請重試");  }else{  alert(textStatus);  }  },  success:function(msg){  $("#tips").html(msg);  } }); }

XMLHttpRequest.readyState: 狀態碼

0 - (未初始化)還沒有調用send()方法

1 - (載入)已調用send()方法,正在發送請求

2 - (載入完成)send()方法執行完成,已經接收到全部響應內容

3 - (交互)正在解析響應內容

4 - (完成)響應內容解析完成,可以在客戶端調用了

XMLHttpRequest.status屬性:一些錯誤代碼對照查詢

HTTP

1xx-信息提示

這些狀態代碼表示臨時的響應。客戶端在收到常規響應之前,應準備接收一個或多個1xx響應。

100-繼續。

101-切換協議。

2xx-成功

這類狀態代碼表明服務器成功地接受了客戶端請求。

200-確定。客戶端請求已成功。

201-已創建。

202-已接受。

203-非權威性信息。

204-無內容。

205-重置內容。

206-部分內容。

3xx-重定向

客戶端瀏覽器必須采取更多操作來實現請求。例如,瀏覽器可能不得不請求服務器上的不同的頁面,或通過代理服務器重復該請求。

301-對象已永久移走,即永久重定向。

302-對象已臨時移動。

304-未修改。

307-臨時重定向。

4xx-客戶端錯誤

發生錯誤,客戶端似乎有問題。例如,客戶端請求不存在的頁面,客戶端未提供有效的身份驗證信息。400-錯誤的請求。

401-訪問被拒絕。IIS定義了許多不同的401錯誤,它們指明更為具體的錯誤原因。這些具體的錯誤代碼在瀏覽器中顯示,但不在IIS日志中顯示︰

401.1-登錄失敗。

401.2-服務器配置導致登錄失敗。

401.3-由于ACL對資源的限制而未獲得授權。

401.4-篩選器授權失敗。

401.5-ISAPI/CGI應用程序授權失敗。

401.7訪問被Web服務器上的URL授權策略拒絕。這個錯誤代碼為IIS6.0所專用。

403-禁止訪問︰IIS定義了許多不同的403錯誤,它們指明更為具體的錯誤原因︰

403.1-執行訪問被禁止。

403.2-讀訪問被禁止。

403.3-寫訪問被禁止。

403.4-要求SSL。

403.5-要求SSL128。

403.6-IP地址被拒絕。

403.7-要求客戶端證書。

403.8-站點訪問被拒絕。

403.9-用戶數過多。

403.10-配置無效。

403.11-密碼更改。

403.12-拒絕訪問映射表。

403.13-客戶端證書被吊銷。

403.14-拒絕目錄列表。

403.15-超出客戶端訪問許可。

403.16-客戶端證書不受信任或無效。

403.17-客戶端證書已過期或尚未生效。

403.18-在當前的應用程序池中不能執行所請求的URL。這個錯誤代碼為IIS6.0所專用。

403.19-不能為這個應用程序池中的客戶端執行CGI。這個錯誤代碼為IIS6.0所專用。

403.20-Passport登錄失敗。這個錯誤代碼為IIS6.0所專用。

404-未找到。

404.0-(無)沒有找到文件或目錄。

404.1-無法在所請求的端口上訪問Web站點。

404.2-Web服務擴展鎖定策略阻止本請求。

404.3-MIME映射策略阻止本請求。

405-用來訪問本頁面的HTTP謂詞不被允許(方法不被允許)

406-客戶端瀏覽器不接受所請求頁面的MIME類型。

407-要求進行代理身份驗證。

412-前提條件失敗。

413請求實體太大。

414-請求URI太長。

415不支持的媒體類型。

416所請求的範圍無法滿足。

417執行失敗。

423鎖定的錯誤。

5xx-服務器錯誤

服務器由于遇到錯誤而不能完成該請求。

500-內部服務器錯誤。

500.12-應用程序正忙于在Web服務器上重新啟動。

500.13-Web服務器太忙。

500.15-不允許直接請求Global.asa。

500.16UNC授權憑據不正確。這個錯誤代碼為IIS6.0所專用。

500.18URL授權存儲不能打開。這個錯誤代碼為IIS6.0所專用。

500.100-內部ASP錯誤。

501-頁眉值指定了未實現的配置。

502-Web服務器用作網關或代理服務器時收到了無效響應。

502.1-CGI應用程序超時。

502.2-CGI應用程序出錯。application.

503-服務不可用。這個錯誤代碼為IIS6.0所專用。

504-網關超時。

505-HTTP版本不受支持。

FTP

1xx-肯定的初步答復

這些狀態代碼指示一項操作已經成功開始,但客戶端希望在繼續操作新命令前得到另一個答復。

110重新啟動標記答復。

120服務已就緒,在nnn分鐘後開始。

125數據連接已打開,正在開始傳輸。

150文件狀態正常,準備打開數據連接。

2xx-肯定的完成答復

一項操作已經成功完成。客戶端可以執行新命令。200命令確定。

202未執行命令,站點上的命令過多。

211系統狀態,或系統幫助答復。

212目錄狀態。

213文件狀態。

214幫助消息。

215NAME系統類型,其中,NAME是AssignedNumbers文檔中所列的正式系統名稱。

220服務就緒,可以執行新用戶的請求。

221服務關閉控制連接。如果適當,請注銷。

225數據連接打開,沒有進行中的傳輸。

226關閉數據連接。請求的文件操作已成功(例如,傳輸文件或放棄文件)。

227進入被動模式(h1,h2,h3,h4,p1,p2)。

230用戶已登錄,繼續進行。

250請求的文件操作正確,已完成。

257已創建“PATHNAME”。

3xx-肯定的中間答復

該命令已成功,但服務器需要更多來自客戶端的信息以完成對請求的處理。331用戶名正確,需要密碼。

332需要登錄帳戶。

350請求的文件操作正在等待進一步的信息。

4xx-瞬態否定的完成答復

該命令不成功,但錯誤是暫時的。如果客戶端重試命令,可能會執行成功。421服務不可用,正在關閉控制連接。如果服務確定它必須關閉,將向任何命令發送這一應答。

425無法打開數據連接。

426Connectionclosed;transferaborted.

450未執行請求的文件操作。文件不可用(例如,文件繁忙)。

451請求的操作異常終止︰正在處理本地錯誤。

452未執行請求的操作。系統存儲空間不夠。

5xx-永久性否定的完成答復

該命令不成功,錯誤是永久性的。如果客戶端重試命令,將再次出現同樣的錯誤。500語法錯誤,命令無法識別。這可能包括諸如命令行太長之類的錯誤。

501在參數中有語法錯誤。

502未執行命令。

503錯誤的命令序列。

504未執行該參數的命令。

530未登錄。

532存儲文件需要帳戶。

550未執行請求的操作。文件不可用(例如,未找到文件,沒有訪問權限)。

551請求的操作異常終止︰未知的頁面類型。

552請求的文件操作異常終止︰超出存儲分配(對于當前目錄或數據集)。

553未執行請求的操作。不允許的文件名。

常見的FTP狀態代碼及其原因

150-FTP使用兩個端口︰21用于發送命令,20用于發送數據。狀態代碼150表示服務器準備在端口20上打開新連接,發送一些數據。

226-命令在端口20上打開數據連接以執行操作,如傳輸文件。該操作成功完成,數據連接已關閉。

230-客戶端發送正確的密碼後,顯示該狀態代碼。它表示用戶已成功登錄。

331-客戶端發送用戶名後,顯示該狀態代碼。無論所提供的用戶名是否為系統中的有效帳戶,都將顯示該狀態代碼。

426-命令打開數據連接以執行操作,但該操作已被取消,數據連接已關閉。

530-該狀態代碼表示用戶無法登錄,因為用戶名和密碼組合無效。如果使用某個用戶帳戶登錄,可能鍵入錯誤的用戶名或密碼,也可能選擇只允許匿名訪問。如果使用匿名帳戶登錄,IIS的配置可能拒絕匿名訪問。

550-命令未被執行,因為指定的文件不可用。例如,要GET的文件並不存在,或試圖將文件PUT到您沒有寫入權限的目錄。

ExtJS 的默認超時時間是30s,超過就會ajax請求失敗,http status code 408。

歡迎點評!也可以是問題反饋和建議

支持Ctrl+Enter提交
暫無留言,快搶沙發!
0

真心很贊,必須打賞!嗯,以資鼓勵~

點此打賞

99%看過的人還會看

永利赌盘网投赌场 | 下一页