国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

詳解AngularJS用Interceptors來統一處理HTTP請求和響應

2024-05-06 15:16:09
字體:
來源:轉載
供稿:網友

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(['$httpProvider', function($httpProvider){ $httpProvider.interceptors.push(HttpInterceptor);}]);

進一步了解

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

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

圖片精選

主站蜘蛛池模板: 广宗县| 宝鸡市| 邮箱| 临城县| 南溪县| 永康市| 汽车| 禹州市| 和田县| 辽阳市| 广水市| 慈利县| 乌鲁木齐县| 邹城市| 秦安县| 湄潭县| 靖西县| 高要市| 贵溪市| 佛教| 昭觉县| 邵阳市| 东平县| 库车县| 修水县| 临西县| 松原市| 永仁县| 鄢陵县| 濮阳市| 越西县| 汤阴县| 东方市| 溧阳市| 屯昌县| 墨江| 高密市| 大理市| 独山县| 彭泽县| 建阳市|