Web 開發中,除了數據操作之外,最頻繁的就是發起和處理各種 HTTP 請求了,加上 HTTP 請求又是異步的,如果在每個請求中來單獨捕獲各種常規錯誤,處理各類自定義錯誤,那將會有大量的功能類似的代碼,或者使用丑陋的方法在每個請求中調用某幾個自定義的函數來處理。這兩種方法基本都不是靠譜之選。好在 AngularJS 提供了 Interceptors ——攔截戰斗機——來對應用內所有的 XHR 請求進行統一處理。
主要功能
Interceptors 有兩個處理時機,分別是:
所以,不難理解它可以用于如下幾個方面:
基本使用
先來看看最基本的使用:
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(['$httpProvider', function($httpProvider){ $httpProvider.interceptors.push(HttpInterceptor);}]);進一步了解
實際的 Interceptor 處理函數中, return 了一個包含四個成員的對象,這四個成員都 不是必須 的,可以按實際情況指定一二,分別如下:
新聞熱點
疑難解答
圖片精選