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等遇到我可以处理在视图中,模板.
我的问题是,什么是获取视图/模板的其他细节的最佳方法,例如拒绝reason和status.它应该在tasks对象中返回还是单独返回?
好吧,首先,你的第一段代码有延迟反模式,让我们解决这个问题:
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)
在这里,您可以通过拒绝来收听状态故障.
| 归档时间: |
|
| 查看次数: |
3216 次 |
| 最近记录: |