【发布时间】:2020-09-29 08:48:05
【问题描述】:
我是 nodejs 新手,正在努力掌握 async/await 功能。我已经阅读了许多其他 SE 帖子和许多博客,但似乎无法获得正确的代码组合来实现预期的程序流程。
我的程序的总体思路是调用 startNextPick() 函数,然后调用 getLeagueFromDraftPicks()。此函数内部是一个查询,需要“等待”完成,但我不确定执行此操作的正确/简单方法。目前,没有等待导致函数返回“未定义”结果。在这种情况下等待查询响应的正确/简单方法是什么?
startNextPick();
async function startNextPick(pickId) {
console.log('A-- starting next pick');
var leagueId = await getLeagueFromDraftPick(pickId);
console.log('B-- leagueId from getLeagueFromDraftPick: '+leagueId);
leagueId = Number(leagueId);
if (leagueId > 0) {
//.... do other stuff here
} else {
console.log('Error with finding league based on draft pick');
}
}
async function getLeagueFromDraftPick(pickId) {
pickId = Number(pickId);
var leagueId;
console.log('1 pickId: '+pickId);
if (pickId <= 0) {
return false;
}
// Get LeagueID from draft based on pickId
// *** Need to "await" this query "
connection.query('select LEAGUE_ID from DRAFT where ID=? limit 1',
[pickId],
function (error, results, fields) {
if (error) {
console.log(error);
return false;
} else {
leagueId = results[0].LEAGUE_ID;
console.log('2-- pickId: '+pickId);
console.log('3-- leagueId: '+leagueId);
return leagueId;
}
});
console.log('4-- leagueId: '+leagueId);
return leagueId;
}
使用 console.log 跟踪代码的时间和流程,很明显需要等待查询,因为 getLeagueFromDraftPick() 的返回值显示未定义但查询结果最终显示正确。
Console.log output
****starting next pick****
A-- starting next pick
1 pickId: 19002
4-- leagueId: undefined
B-- leagueId from getLeagueFromDraftPick: undefined
Error with finding league based on draft pick
2-- pickId: 19002
3-- leagueId: 52
** 解决方案 ** 使用@cyberwombat 回答并进行一些修改,我能够让它工作。以下是工作代码:
async function startNextPick(pickId) {
console.log('A-- starting next pick');
var leagueId = await getLeagueFromDraftPick(pickId);
console.log('B-- leagueId from getLeagueFromDraftPick: '+leagueId);
}
async function getLeagueFromDraftPick(pickId) {
pickId = Number(pickId);
console.log('1 pickId: '+pickId);
if (pickId <= 0) {
return false;
}
// Get LeagueID from draft based on pickId
// *** Need to "await" this query "
const leagueId = await new Promise(function(resolve, reject) {
connection.query('select LEAGUE_ID from DRAFT where ID=? limit 1',
[pickId],
function (error, results, fields) {
if (error) {
console.log(error);
reject(error);
} else {
if (results[0]) {
console.log('2-- pickId: '+pickId);
console.log('3-- leagueId: '+results[0].LEAGUE_ID);
resolve(results[0].LEAGUE_ID);
} else {
resolve(0); }
}
});
});
console.log('4-- leagueId: '+leagueId);
return leagueId;
}
Console output:
****starting next pick****
A-- starting next pick
1 pickId: 19031
2-- pickId: 19031
3-- leagueId: 52
4-- leagueId: 52
B-- leagueId from getLeagueFromDraftPick: 52
【问题讨论】:
标签: node.js asynchronous async-await