$q.all 和嵌套承诺



有一个关于在 Angular 中使用$q时同步嵌套承诺的问题。下面的代码会确保等待整个承诺链吗?这意味着在 $q.all 块中等待对返回承诺的服务的嵌套调用?

var call1 = service1.get('/someUr').then(function(){
  return service2.get('/someUrl2'); //returns promise
});
var call2 = service3.get('/someUr').then(function(){
  return 'hello';
});
var call3 = service4.get('/someUr').then(function(){
  return service3.get('/someUrl3');//returns promise
});
$q.all(call1,call2,call3).then(function(){
  console.log('All asynch operations are now completed');
});

基本上:当前代码是否有机会在所有嵌套承诺解析之前执行 $q.all 的然后?还是递归的?

是的,看起来凯文是对的。我还在角度中创建了一个快速测试来确认行为。

angular.module('myModule').controller('testController', function ($q,$scope) {
  function promiseCall(data,timeout) {
    var deferred = $q.defer();
    setTimeout(function() {
      deferred.resolve(data);
      console.log(data);
    }, timeout);
    return deferred.promise;
  }
  var a = promiseCall('call1 a',1000).then(function(){
    return promiseCall('call2 a',50);
  });
  var b = promiseCall('call1 b',500);
  var c = promiseCall('call1 c',1000).then(function(){
    return promiseCall('call2 c',50).then(function(){
      return promiseCall('call3 c',6000);
    });
  });
  $q.all([a,b,c]).then(function(res){
    console.log('all calls are done');
  });
});

相关内容

  • 没有找到相关文章

最新更新