按顺序归还承诺

时间:2016-07-29 15:58:10

标签: javascript angularjs angular-promise

我面临使用$q#all方法返回承诺的问题。

我想让承诺相互依赖,

如果我设置obj1, obj2 and obj3,我希望以相同的顺序获取它们。

我怎样才能做到这一点?

Factory:

mainFactory.$inject = ['$http', '$q'];

function mainFactory($http, $q) {
  var mainFactory = {
    getPromises: getPromises
  };

  return mainFactory;

  function getPromises(id) {
    promises = {
      'obj1': $http.get('http1'),
      'obj2': $http.get('http2'),
      'obj3': $http.get('http3'),
      'obj4': $http.get('http4', { params: { 'id': id } }),
      'obj5': $http.get('http5'),
      'obj6': $http.get('http6', { params: { 'id': id } })
    };

    return $q.all(promises);
  }
}

Controller:

MainCtrl.$inject = ['mainFactory'];

function MainCtrl(mainFactory) {
  var vm = this;
  mainFactory.getPromises(id)
    .then(getResponse)
    .catch(getError);

  function getResponse(response) {
    var keys = Object.keys(response), i = keys.length;
    while (i--) {
      var key = keys[i];
      console.log(key); // I want all the keys in order, i.e. => obj1, obj2.. and so on
      var value = response[key].data;
      switch(key) {
        ...
      }
    }
  }

  function getError(error) {
    console.log(error);
  }
}

修改

我也尝试过这种方式:

var promises = {};
return $http.get('/admin/http1.json').then(function (value) {
    promises['obj1'] = value;
  })
.then(function (result) {
    return $http.get('/admin/http2.json').then(function (value) {
    promises['obj2'] = value;
  });
}).then(function (result) {
    return $http.get('/admin/http3.json').then(function (value) {
    promises['obj3'] = value;
  });
});     
return $q.all(promises);

2 个答案:

答案 0 :(得分:1)

修改2

错误,我刚刚复制了上面的代码而没有意识到它是一个对象。 LOL。

promises = [
  $http.get('http1'),
  $http.get('http2'),
  $http.get('http3'),
  $http.get('http4', { params: { 'id': id } }),
  $http.get('http5'),
  $http.get('http6', { params: { 'id': id } })
]

修改1

抱歉,我没有注意到评论Jared Smith是正确的。

  

对象键本质上是无序的。改为使用数组。

编辑0

对象键不会被订购。使用数组声明你的承诺。

promises = [
  $http.get('http1'),
  $http.get('http2'),
  $http.get('http3'),
  $http.get('http4', { params: { 'id': id } }),
  $http.get('http5'),
  $http.get('http6', { params: { 'id': id } })
]

$q.all(promises)
  .then(functions(resolves){
      // resolves here is an array
  }).catch(function(err){ 
      // throw err 
  });

答案 1 :(得分:1)

使用$q.all将解决每个承诺无特定顺序。如果您希望在每个承诺解决后执行它们,请使用 promise chaining

function getPromises(id) {
  var getObjA = function () {
    return $http.get('http1');
  };

  var getObjB = function () {
    return $http.get('http2');
  };

  var getObjC = function () {
    return $http.get('http3');
  };

  var getObjD = function () {
    return $http.get('http4', { params: { 'id': id } });
  };

  var getObjE = function () {
    return $http.get('http5');
  };

  var getObjF = function () {
    return $http.get('http5', { params: { 'id': id } });
  };

  return getObjA()
    .then(getObjB)
    .then(getObjC)
    .then(getObjD)
    .then(getObjE)
    .then(getObjF);
}

编辑:作为附加信息,您可以通过在此处放置一个catch语句来捕获任何这些承诺中的任何错误

getPromises("id")
   .then(<success callback here>)
   .catch(<error callback that will catch error on any of the promises>);

意思是,一旦承诺失败,下面的所有后续承诺都不会被执行,并且会被你的捕获声明捕获