async.queue 带有 async/await 风格的函数

Ros*_*don 5 javascript queue async-await

我正在尝试创建一个函数,该函数从对象数组构建队列,然后通过调用多个函数来处理每个对象。

处理函数是异步函数,在需要排队之前,我使用 async/await 模式实现。我认为这是必要的,因为每个都依赖于前一个的输出,我不想有大量的嵌套 promise.then

即以前我有:

await Promise.all(messages.map(async(message) => {
    let activity = await activityController.getActivity(message.activityId);
    let url = await SMSController.getUrl(message.Token);
    let smsSendResult = await SMSController.sendSMS(messageString, activity.mobileNo);
    // etc...
}
Run Code Online (Sandbox Code Playgroud)

现在我想要做的是:

let queue = async.queue((message, done) => {
     let activity = await activityController.getActivity(message.activityId);
     let smsSendResult = await SMSController.sendSMS(messageString, activity.mobileNo);
    // etc...
}

messages.forEach((message) => {
    queue.push(message);
})
Run Code Online (Sandbox Code Playgroud)

我有问题,虽然这会导致

SyntaxError: await is only valid in async function

我似乎不太明白如何解决这个问题。

Giu*_*ini 1

您正在寻找async.series,而不是async.queue

series(tasks, callbackopt)

连续运行集合中的函数tasks,每个函数在前一个函数完成后运行。

所以只需遵循文档即可:

const messageCallbacks = messages.map(function(msg) {
    return async function(callback) {callback(await handleMessage(msg));
});


async.series(messageCallbacks,
// optional callback
function(err, results) {
    // results is now equal to whatever handleMessage resolves to
});
Run Code Online (Sandbox Code Playgroud)

没有异步:

async function asyncMessageQueue(messages) {
    const results = [];
    for(var i=0,l=messages.length; i<l; ++i) {
        results.push(await handleMessage(messages[i]));
    }
    return results;
}

async function handleMessage(message) {
        let activity = await activityController.getActivity(message.activityId);
        let url = await SMSController.getUrl(message.Token);
        let smsSendResult = await SMSController.sendSMS(messageString, activity.mobileNo);
        // rest of the code
};
Run Code Online (Sandbox Code Playgroud)

这还允许您提供带有任何先前结果的下一条消息:,只需更改await handleMessage(messages[i])await handleMessage(messages[i], results)然后:

async function handleMessage(message, prevResults) {
        // rest of the code
};
Run Code Online (Sandbox Code Playgroud)