我需要在异步函数中的每个语句之前等待吗?

我有一个异步函数,其中某些事情似乎先于其他事情乱序执行。我认为这是因为我正在使用异步功能。但是如何使它以正确的顺序(编写方式)执行。我需要在每个这样的语句之前放置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
},
wangyande108 回答:我需要在异步函数中的每个语句之前等待吗?

仅在预期返回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);
}
,

将整个块包装在try catch中,并在返回Promises的语句之前等待

本文链接:https://www.f2er.com/2839485.html

大家都在问