一尘不染

如何“等待”回调返回?

javascript

当使用简单的回调(例如下面的示例)时:

test() {
  api.on( 'someEvent', function( response ) {
    return response;
  });
}

如何更改功能以使用异步/等待?具体来说,假设“
someEvent”被保证只能被调用一次,那么我希望函数测试是一个异步函数,该异步函数在执行回调之前不会返回,例如:

async test() {
  return await api.on( 'someEvent' );
}

阅读 311

收藏
2020-05-01

共1个答案

一尘不染

async/await不是魔术。异步函数是可以为您解开Promises的函数,因此您需要api.on()返回一个Promise才能起作用。像这样:

function apiOn(event) {
  return new Promise(resolve => {
    api.on(event, response => resolve(response));
  });
}

然后

async function test() {
  return await apiOn( 'someEvent' ); // await is actually optional here
                                      // you'd return a Promise either way.
}

但这也是一个谎言,因为异步函数也返回Promises本身,所以您实际上不会从中获取值test(),而是对值的承诺,可以这样使用:

async function whatever() {
  // snip
  const response = await test();
  // use response here
  // snip
}
2020-05-01