我需要在异步函数中的每个语句之前放置 await 吗?
Do I need to put await before every statement in an async function?
我有一个异步函数,其中有些事情似乎先于其他事情乱序执行。我认为这是因为我正在使用异步函数。但是我怎样才能让它以正确的顺序执行(它的编写方式?)。我需要在每个这样的语句之前加上 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
},
仅在预期 return 一个 Promise
符号化的语句中使用 await,等待承诺被 returned。所以,不是在每条指令中,而是在你需要的地方。
绝对如你所想wrong.You只需要在异步函数前加上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);
}
将整个块包装在 try catch 中,并在 return Promises
的语句之前放置 await
我有一个异步函数,其中有些事情似乎先于其他事情乱序执行。我认为这是因为我正在使用异步函数。但是我怎样才能让它以正确的顺序执行(它的编写方式?)。我需要在每个这样的语句之前加上 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
},
仅在预期 return 一个 Promise
符号化的语句中使用 await,等待承诺被 returned。所以,不是在每条指令中,而是在你需要的地方。
绝对如你所想wrong.You只需要在异步函数前加上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);
}
将整个块包装在 try catch 中,并在 return Promises
的语句之前放置 await