我希望能够设置一个 AngularJS http 拦截器,该拦截器将设置$rootScope.loading
为true
或false
,具体取决于当前是否正在进行 AJAX 请求。
到目前为止,我已经将以下内容放在一起:
angular.module('myApp')
.config(function ($httpProvider) {
$httpProvider.responseInterceptors.push('loadingInterceptor');
var loadingFunction = function (data, headersGetter) {
$rootScope.loading = true
return data;
};
$httpProvider.defaults.transformRequest.push(loadingFunction);
})
.factory('loadingInterceptor', function ($q, $window, $rootScope) {
return function (promise) {
return promise.then(function (response) {
$rootScope.loading = false;
return response;
}, function (response) {
$rootScope.loading = false;
return $q.reject(response);
});
};
});
但是我无法注入$rootScope
配置块,所以$rootScope.loading
当 HTTP 请求开始时我无法设置变量。
我在这里错过了什么吗?我该怎么做?