如何在$ state更改时使用promis取消所有挂起的$ resource请求

时间:2017-12-11 15:13:52

标签: angularjs angular-ui-router ngresource

我正在尝试在发生状态更改时停止所有待处理的请求。以下代码适用于$ http但不适用于$ resource。

                 var cancel=$q.defer();
    $http.get('api/cafservicestatus',{timeout:cancel.promise,cancel:cancel}).then(onsuccess,onerror);

    function onsuccess(result) {
        console.log(result)
    }

    function onerror(error) {
        console.log(error)
    }


    function stopHttp() {
        $http.pendingRequests.forEach(function(request) {
            if (request.cancel) {
                request.cancel.resolve();
            }
        });
    }

但是此代码不适用于$ resource  以下是$ resource

的示例代码
             $resource(resourceUrl, {}, {
        'query': { method: 'GET', isArray: true,timeout:$q.defer().promise,cancel:$q.defer()},
        'get': {
            method: 'GET',
            transformResponse: function (data) {
                if (data) {
                    data = angular.fromJson(data);
                }
                return data;
            }
        },
        'update': { method:'PUT' }
    }); 

如何使用$ resource

停止所有请求

1 个答案:

答案 0 :(得分:2)

我已经想出了这个。你必须在你的请求中添加一个可取消的:true并使用$ resource的$ cancelRequest()方法在你的控制器中取消请求。

例如,在你的情况下

$resource(resourceUrl, {}, {
    'query': { method: 'GET', isArray: true,cancellable:true},
    'get': {
        method: 'GET',
        transformResponse: function (data) {
            if (data) {
                data = angular.fromJson(data);
            }
            return data;
        }
    },
    'update': { method:'PUT' }
}); 

并在您的控制器内

 var aborted= YourService.query();

//and later on state change

  $scope.$on('$stateChangeSuccess',function(event){
     aborted.$cancelRequest();
      }
      );