Angularjs $q.all和嵌套承诺

Angularjs $q.all和嵌套承诺,angularjs,q,angular-promise,Angularjs,Q,Angular Promise,在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

在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');
});

基本上:当前代码是否有可能在解析所有嵌套承诺之前执行then$q.all?还是它是递归的?

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

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');
  });

});

不,我不这么认为。
$q.all()
将等待
call1
call2
call3
一起解析,然后触发
then()
函数,但是从
call1
call3
返回的嵌套异步调用将不会被等待。我的印象是它会等待。目前我手头没有angular env来测试这一点,但使用本机承诺,它肯定会等待@凯文布看起来你是对的。我创建了一个快速的角度测试波纹管。