搜索
javascript - 关于promise.all的问题
巴扎黑
巴扎黑 2017-04-10 16:32:30
[JavaScript讨论组]
Promise.all 不应该是数组中的所有promise执行完才会调用then中的方法吗。为什么当getGroupInfo,getUserInfo还处于pending状态的时候就执行then中的方法了呢?

Promise.all([getGroupInfo,getUserInfo])
.then((group,user)=>{
    console.log(group); //undefined
    console.log(user); //undefined
});

var getGroupInfo = new Promise((resolve,reject) => {
    $.get(basePath + '/getYourGroupsInfo',function(data){
        var groups = data.data;
        groups.forEach(function(group){
            $(".group").append(`
                <a class="item" data-id="${group._id}">${group.name}</a>
            `);
        });
        resolve(groups);
    });
});

var getUserInfo = new Promise( (resolve,reject) => {
    $.get(basePath + "/getLoginInfo",function(data){
        user = data.user
        console.log(data);
        resolve(user);
    });
});
巴扎黑
巴扎黑

全部回复(2)
大家讲道理

你代码确定是这样写的么?
为什么Promise.all先调用,getGroupInfo/getUserInfo后定义呢?

迷茫

首先,then方法是你自己调用的,所以then调用的的时机取决于你自己。

其次,Promise.all([p1, p2])在[p1, p2]都fulfill或则某个reject后,会调用then(fn)中的fn,fn中的参数一般只有一个,用法如下:

var p1 = Promise.resolve(3);
var p2 = 1337;
var p3 = new Promise(function(resolve, reject) {
  setTimeout(resolve, 100, "foo");
}); 

Promise.all([p1, p2, p3]).then(function(values) { 
  console.log(values); // [3, 1337, "foo"] 
});

详细用法请看MDN:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/all

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号