[英]Error handling in $q.all()
我在控制器中使用了两个工厂调用。 在这两个陷阱中,我想调用单独的函数来处理错误。
我有的 :
someFactory.functionOne().then(function (data) {
$scope.one = data;
}).catch(functionToHandleOne());
someFactory.functionTwo().then(function (data) {
$scope.two = data;
}).catch(functionToHandleTwo());
我可以用$ q.all()这样更好的方法吗
$q.all({
one: someFactory.functionOne(),
two: someFactory.functionTwo()
}).then (function (data) {
$scope.one = data.one;
$scope.two = data.two;
}).catch(
//here I have to call functions functionToHandleOne() and functionToHandleTwo() according to error caused which function call
);
您的解决方案非常好。 当然,您在“捕获”中缺少错误回调函数,并且缺少error参数。
一个例子:
$q.all({
one: someFactory.functionOne(),
two: someFactory.functionTwo()
}).then (function (data) {
$scope.one = data.one;
$scope.two = data.two;
}).catch(function(e){
if(e.argument == 'error1')
functionToHandleOne()();
else
functionToHandleTwo()();
});
var app = angular.module('plunker',[]);
app.factory('json',function($q,$http){
return function(files){
var promises = files.map( function(file){
var deffered = $q.defer();
$http({
url : file,
method: 'GET'
}).
success(function(data){
deffered.resolve(data);
}).
error(function(error){
deffered.reject();
});
return deffered.promise;
})
return $q.all(promises);
}
});
app.controller('MainCtrl', function($scope,json) {
$scope.name = 'World';
json(['a.json','b.json']).then(function(datas){
$scope.a = datas[0]
$scope.b = datas[1]
})
});
在上面的完整代码中,您可以找到所需的一切。 喜欢
$ q是在工厂中传递的,如果您有多个功能,则可以将它们全部调用到一个工厂中,并使它们真正满足您的需求。
您可以在控制器中看到,如下面的代码所示,它将返回数据。
json(['a.json','b.json']).then(function(datas){
$scope.a = datas[0]
$scope.b = datas[1]
})
“数据”返回所有调用的多个值,因此您需要与数组一起使用。
请让我知道是否需要解决或需要更多研究
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.