麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 網站 > WEB開發 > 正文

AngularJS 中利用 Interceptors 來統一處理 HTTP 的錯誤

2024-04-27 15:14:04
字體:
來源:轉載
供稿:網友

Web 開發中,除了數據操作之外,最頻繁的就是發起和處理各種 HTTP 請求了,加上 HTTP 請求又是異步的,如果在每個請求中來單獨捕獲各種常規錯誤,處理各類自定義錯誤,那將會有大量的功能類似的代碼,或者使用丑陋的方法在每個請求中調用某幾個自定義的函數來處理。這兩種方法基本都不是靠譜之選。好在 AngularJS 提供了 Interceptors ——攔截戰斗機——來對應用內所有的 XHR 請求進行統一處理。

主要功能

Interceptors 有兩個處理時機,分別是:

其它程序代碼執行 HTTP 請求之后,在實際從瀏覽器發出請求之前,即處理請求得到請求的響應之后,在交給其它程序代碼處理之前,即處理請求的響應

所以,不難理解它可以用于如下幾個方面:

全局處理錯誤統一進行身份驗證一類的處理對所有發出去的請求進行預處理對所有收到的響應進行預處理做一些增強用戶體驗的操作,例如顯示一個進度條

基本使用

先來看看最基本的使用:

var app = angular.module('app', []);// 定義一個 Service ,稍等將會把它作為 Interceptors 的處理函數app.factory('HttpInterceptor', ['$q', HttpInterceptor]);function HttpInterceptor($q) {  return {    request: function(config){      return config;    },    requestError: function(err){      return $q.reject(err);    },    response: function(res){      return res;    },    responseError: function(err){      if(-1 === err.status) {        // 遠程服務器無響應      } else if(500 === err.status) {        // 處理各類自定義錯誤      } else if(501 === err.status) {        // ...      }      return $q.reject(err);    }  };}// 添加對應的 Interceptorsapp.config(['$http進一步了解

實際的 Interceptor 處理函數中, return 了一個包含四個成員的對象,這四個成員都 不是必須的,可以按實際情況指定一二,分別如下:

request :接收一個參數,它是 $http 中的標準 config 對象,同時也需要返回一個標準 config ,此時可以添加各類身份驗證信息,同時也可在此啟動進度條requestError :當有多個 Interceptor 的時候, requestError 會在前一個 Interceptor 拋出錯誤或者執行 $q.reject() 時執行,接收的參數就對應的錯誤response :接受一個請求對象參數,可以不處理就直接返回,此時也可以將進度條顯示為成功完成,當然,如果后端 API 返回自定義錯誤時,HTTP 的狀態碼仍然是 200 得話,便在這里處理自定義錯誤,也可以對返回數據做一些處理,注意要將進度條置為完成responseError :這個是重頭戲,即可以處理標準的 Http 錯誤,如服務器沒有響應時,或者
php 之類的 CGI 經常出現的 502 一類,還可以處理 HTTP 狀態碼不是 200 的各類自定義錯誤

上面四個中,前兩個是請求的前置處理,后兩個是針對請求的響應的處理。

幾個相關的庫

顯示進度:

NProgressNgProgress NProgress for AngularJSrc-progressprogress-full-widthprogress-svg

提示框:

toastrngToast toast for AngularJSangular-toastk-toastnotieng-notiecorner-notie

完整的例子

具體請參見代碼( Github 、 Coding.NET ),例子中演示了如何統一處理錯誤,并使用 toastr 提示,并使用 NProgress 顯示一個進度條。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产精品18久久久久久久久 | 国产午夜探花 | 亚洲人成电影在线 | 国产视频在线免费观看 | 成人在线观看污 | 黄色网络免费看 | 国产免费一区二区三区网站免费 | 把娇妻调教成暴露狂 | 久久国产精品二区 | 日日鲁一鲁视频 | 亚洲精品午夜在线 | 久久久精品精品 | 日本在线视频免费观看 | 久久久久久69 | 亚州欧美在线 | 欧美日韩1区2区3区 黄片毛片一级 | 国产中文99视频在线观看 | 亚洲精品成人在线视频 | 露脸各种姿势啪啪的清纯美女 | 国产无遮挡一级毛片 | 91av久久| 亚洲xxx在线观看 | 国产精品美女一区二区 | 国产女同疯狂激烈互摸 | 精品一区二区三区在线观看国产 | 成人毛片免费 | 中文字幕视频在线播放 | 一本色道久久99精品综合蜜臀 | 激情福利视频 | 成人午夜视频免费看 | 中文区永久区 | 久久国产精品免费视频 | 欧美成人免费看 | 日本一级黄色大片 | 欧美女优一区 | 亚州精品在线视频 | 亚洲一区二区三区日本久久九 | 九九精品在线观看视频 | www久久艹 | 国产亚洲精品久久777777 | 91精品国产91久久久 |