我有一个异步函数,其中某些事情似乎先于其他事情乱序执行。我认为这是因为我正在使用异步功能。但是如何使它以正确的顺序(编写方式)执行。我需要在每个这样的语句之前放置 还是我的语法不正确? 答案 0 :(得分:1) 仅在预期返回 答案 1 :(得分:1) 您的想法绝对是错误的。您只需在异步函数之前添加 答案 2 :(得分:0) 将整个块包装在try catch中,并在返回Promises的语句之前等待await
吗?async foodDelivered(order_id, table_id)
{
await let tmp_order_id = order_id
await let deliveryTime = 0
await this.btnDeliveredLoading = true
await const index = store.table_timers.findIndex(({ order_id }) => order_id === tmp_order_id)
await if (index != -1) {
// Stop timer
await clearInterval(store.table_timers[index].interval)
// Remove timer
await store.table_timers.splice(
store.table_timers.findIndex(({ order_id }) => order_id === tmp_order_id), 1
)
await deliveryTime = store.table_timers[index].time
}
try {
await OrderHistory.updateColor({
order_id: order_id,
table_id: table_id,
action: 'FOOD_DELIVERED',
})
// Save delivery time
await OrderHistory.saveDeliveryTime({
deliveryTime: deliveryTime,
order_id: order_id,
})
// Refresh
await OrderHistoryClass.getTotalOrderHistory({
date: moment().format('YYYY-MM-DD'),
})
let tables = await Data.getTables()
await store.tables = tables.data
await this.drawerOpened = false
}
await this.btnDeliveredLoading = false
},
3 个答案:
Promise
符号的语句中使用await,该语句要等到返回诺言。因此,并非在所有说明中都有提示,而是在您需要的地方提示。await
,而不是每个语句。async function logAsync(a) {
return Promise.resolve(a);
}
function logSync(a) {
console.log(a);
}
function combination() {
// you only add await before async functions
await logAsync("async 1");
// this does not need await before
logSync(1);
logSync(2);
logSync(3);
}