在一个异步函数中等待几个promise

时间:2016-09-07 13:58:38

标签: javascript async-await ecmascript-next

我试图利用es7异步函数,即

async function stepVerifyIdentity(nextState, replace, callback) {
    const val1 = await promise1('Param1')
    const val2 = await promise2('Param2')
    const val3 = await promise3('Param3')
    if (!val1 && (!val2 || !val3)) {
        console.log('Do something')
    } 
}

这里所有promise *函数进行ajax调用并返回truefalse如果ajax响应满足传递的参数,我相信我不能连续使用3个等待,因此需要一种方法来等待所有这些调用以某种方式返回它们的值。

1 个答案:

答案 0 :(得分:7)

您可以根据需要多次使用await,因此您的示例可以满足您的需求。

但是,也许你会认为Promise.all更漂亮:

async function stepVerifyIdentity(nextState, replace, callback) {
  const [ val1, val2, val3 ] = await Promise.all([
    promise1('Param1'),
    promise2('Param2'),
    promise3('Param3')
  ])

  if (!val1 && (!val2 || !val3)) {
    console.log('Do something')
  } 
}