AngularJS使用UI-Router处理拒绝的响应

Dar*_*ech 6 promise angularjs angular-ui-router

我有一个服务,它在Angular中包装我的API调用:

var ConcernService = {

    list: function (items_url) {
        var defer = $q.defer();
        $http({method: 'GET', 
            url: api_url + items_url})
            .success(function (data, status, headers, config) {
                defer.resolve(data, status);
            })
            .error(function (data, status, headers, config) {
                defer.reject(data, status);
            });
        return defer.promise;
    },
Run Code Online (Sandbox Code Playgroud)

然后我的应用程序配置,UI-Router:

    .config(function($stateProvider){

        $stateProvider

        .state('default', {
            url: '/',
            resolve: {
                tasks: function ($stateParams, ConcernService) {
                    return ConcernService.list('tasks/').then(
                        function (tasks)   { return tasks; },
                        function (reason)  { return []; }
                    );
                },
                ...
            }
        }
    });
Run Code Online (Sandbox Code Playgroud)

这是最基本的配置,我可以蒙混过关,这基本上只是返回如果一个空的对象403,404等遇到我可以处理在视图中,模板.

我的问题是,什么是获取视图/模板的其他细节的最佳方法,例如拒绝reasonstatus.它应该在tasks对象中返回还是单独返回?

Ben*_*aum 7

好吧,首先,你的第一段代码有延迟反模式,让我们解决这个问题:

list: function (items_url) {
    return $http.get(api_url + items_url); // $http already returns a promise
},
Run Code Online (Sandbox Code Playgroud)

另请注意,延迟拒绝和履行是单一值,因此您的多个返回值在此处不起作用.

现在,我们来看看路由器.首先,您的第一个履行处理程序是多余的.

.state('default', {
        url: '/',
        resolve: {
            tasks: function ($stateParams, ConcernService) {
                return ConcernService.list('tasks/'); // result.data contains the data here
            },
            ...
        }
Run Code Online (Sandbox Code Playgroud)

现在,我们遇到的问题是拒绝的情况?

好吧,听听$stateChangeError:

$rootScope.$on('$stateChangeError', 
function(event, toState, toParams, fromState, fromParams, error){ ... })
Run Code Online (Sandbox Code Playgroud)

在这里,您可以通过拒绝来收听状态故障.