首页 > Web开发 > 详细

AngularJS中处理多个promise

时间:2016-02-02 06:27:11      阅读:250      评论:0      收藏:0      [点我收藏+]

 

在使用AngularJS中处理promise的时候,有时会碰到需要处理多个promise的情况。

最简单的处理就是每个promise都then。如下:

 

var app = angular.module("app",[]);

app.controller("AppCtrl", function($q. $timeout){
    var one = $q.defer();
    var two = $q.defer();
    var three = $q.defer();
    
    $timeout(function(){
        one.resolve("one done");
    }, Math.random() * 1000)
    
    $timeout(function(){
        two.resolve("two done");
    }, Math.random() * 1000)  
    
    $timeout(function(){
        three.resolve("three done");
    }, Math.random() * 1000)    
    
    functioin success(data){
        console.log(data);
    }
    
    one.promise.then(success);
    two.promise.then(success);
    three.promise.then(success);
})

 

有没有更好的方式?

$q.all方法可以接受promise的一个数组,按如下调用:

var all = $q.all([one.promise, two.promise, three.promise]);
all.then(success);

AngularJS中处理多个promise

原文:http://www.cnblogs.com/darrenji/p/5176683.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!