我有一个基于组件的Angular应用程序,其中各个组件加载其各自的数据。当出现错误时,通常希望组件显示错误消息。
但是,在某些情况下,我希望组件忽略错误,并将其留给一些全局错误处理机制来捕获。
拦截器:
angular.module("...").factory("httpInterceptor", function($q) {
return {
responseError: function(response) {
// (1)
return $q.reject("I AM CALLED FIRST")
}
})
服务:
angular.module("...").service("myService", function($http){
return {
fetchData: function(){
return $http.get("...")
}
}
})
控制器:
angular.module("...").controller("MyController", function(myService){
myService.fetchData()
.then(function(){ ... })
.catch(function() {
// (2)
//I AM CALLED LAST
})
})
在大多数情况下,我希望错误处理在控制器中进行(即(2)点)。如果控制器决定忽略错误(省略catch),则拦截器仍然可以捕获错误。问题在于,拦截器不知道控制器是否打算捕获错误,因为它在控制器之前被调用。因此,拦截器不知道是否应该显示错误消息(我不想同时出现全局和本地错误消息)。
如何捕获控制器忽略的HTTP错误?