如何解析外部异步函数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
来解决这个问题。
答案 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();