节点承诺和返回值

问题描述 投票:1回答:2

我一直在努力加强对JavaScript的承诺和异步性的理解。我知道下面的示例将无法正常工作,“someStuff”将返回一个空数组。我也相信我明白这是因为“doPromise”没有阻塞,所以循环完成并在“doPromise”解决之前返回一个空数组。

我不明白的是我如何以适当的方式完成此示例中表达的相同功能。

我想我的问题是:做到这一点的“正确”方法是什么?提前致谢!

function doPromise(number){
    return new Promise((resolve,reject)=>{
        resolve(number + 10);
    });
}

function someStuff(){
    var values = [];
    for(var i = 0; i < 10;i++){
        doPromise(i).then((sum)=>{
            values.push(sum);
        });
    }
    return values;
}

console.log(someStuff());
javascript asynchronous promise blocking
2个回答
1
投票

“doPromise”不会阻塞,因此循环完成并在任何“doPromise()”解析之前返回一个空数组。

是。这也意味着您无法同步返回结果数组,只能在所有promise已解决后获取值。所以你的someStuff函数也是异步的,所以它应该返回一个promise(对于结果数组)。

要获得承诺数组的结果数组的承诺,您可以使用Promise.all函数。

function someStuff() {
    var promises = [];
    for (var i=0; i<10; i++) {
        promises.push(doPromise(i));
    }
    return Promise.all(promises);
}

someStuff().then(values => {
    console.log(values);
});

0
投票

你可以使用async await

function doPromise(number) {
    return new Promise(( resolve, reject) => {
        resolve(number + 10);
    });
}


async function someStuff() {
    var values = [];

    for ( var i = 0 ; i < 10 ; i++ ) {
        const sum = await doPromise(i).catch(ex => console.log("error: ", ex));
        values.push(sum);
    }
    return values;
}

someStuff().then( val => {
    console.log(val);
});

您应该注意,在async函数调用中不使用.then从async函数返回时只显示未解析的promise(pending)。为了能够在不使用.then的情况下执行此操作,您必须等待几个月,直到TC39标准化为止等待

© www.soinside.com 2019 - 2024. All rights reserved.