加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

angularjs – $q.all和嵌套的承诺

发布时间:2020-12-17 07:09:49 所属栏目:安全 来源:网络整理
导读:在Angular中使用$q时,有一个关于同步嵌套promise的问题. 以下代码是否会确保等待整个承诺链?意味着在$q.all块中等待返回promises的服务的嵌套调用? var call1 = service1.get('/someUr').then(function(){ return service2.get('/someUrl2'); //returns pr
在Angular中使用$q时,有一个关于同步嵌套promise的问题.
以下代码是否会确保等待整个承诺链?意味着在$q.all块中等待返回promises的服务的嵌套调用?

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

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

解决方法

是的,看起来Kevin是正确的.我还创建了一个角度快速测试来确认行为.

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

});

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读