我需要在异步函数中的每个语句之前放置 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