繁体   English   中英

$ q.all()中的错误处理

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM