如何从内部函数解析外部异步函数

时间:2015-12-24 02:39:33

标签: javascript async-await ecmascript-next

如何解析外部异步函数askIfUserIsAMinor,并在用户回答对话框提示后使用布尔值指示用户的次要状态(true / false)?例如:

async function askIfUserIsAMinor() {
  let dialogButtons = [
    {
      text: "Yes",
      onPress: () => {
        // I want to return 'false' on the outer async function 
      }
    }, 
    {
      text: "No",
      onPress: () => {
        // I want to return 'true' on the outer async function 
      }
    }
  ];
  dialog.prompt("Are you above the age of 18?", dialogButtons);
}

let userIsAMinor = await askIfUserIsAMinor();
if (userIsAMinor) {
  // let user proceed
} else {
  // show something else
}

是的,还有很多其他方法可以在没有async / await的情况下解决这个问题,但是我的用例要比这复杂得多,这只是一个简化的场景。在ES6中,可以通过让askIfUserIsAMinor返回一个promise并让内部onPress函数在外部promise上调用resolve来解决这个问题。

1 个答案:

答案 0 :(得分:3)

这段代码实际上是正常的 - 宣传了dialog.prompt,然后等待async function testMinor中的承诺 - 我之前发布的代码落入其他人总是陷入的同一个陷阱中,以某种方式可以思考异步代码同步...

function askIfUserIsAMinor() {
    return new Promise(function(resolve) {
        let dialogButtons = [{
            text: "Yes",
            onPress: () => resolve(true)
        }, {
            text: "No",
            onPress: () => resolve(false)
        }];
        dialog.prompt("Are you above the age of 18?", dialogButtons);
    });
}
async function testMinor() {
    let userIsAMinor = await askIfUserIsAMinor();
    if (userIsAMinor) {
      // let user proceed
    } else {
      // show something else
    }
}

async function askIfUserIsAMinor() {
    let userIsAMinor = await new Promise(function(resolve) {
        let dialogButtons = [{
            text: "Yes",
            onPress: () => resolve(true)
        }, {
            text: "No",
            onPress: () => resolve(false)
        }];
        dialog.prompt("Are you above the age of 18?", dialogButtons);
    });
    if (userIsAMinor) {
      // let user proceed
    } else {
      // show something else
    }
}
askIfUserIsAMinor();