亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

請問es7的一個 async/await, await為什么有的時候是可以省略的?

請問es7的一個 async/await, await為什么有的時候是可以省略的?

躍然一笑 2019-03-22 18:14:25
測試代碼:async function fun1(){    return fun2();// 這里的 await 為什么可以省略?加上await結果也是一樣的}async function fun2(){    return fun3();// 這里的 await 為什么可以省略?加上await結果也是一樣的}async function fun3(){    return new Promise(resolve=>{        console.log('fun3');        resolve('fufff 3 ret');    })}async function testfun1(){    const ret = await fun1();    console.log(ret);}testfun1()fun1 fun2 加不加 await 輸出都是一樣的.fun3fufff 3 ret這到底是為什么呢?
查看完整描述

1 回答

?
長風秋雁

TA貢獻1757條經驗 獲得超7個贊

  1. 首先,awati后面應該跟Promise實例。

  2. 其次,async函數返回的是Promise實例。

具體到樓主的例子,fun1、fun2前面的async是多余的,因為 fun1() => fun2() => fun3() 已經返回了Promise實例。

可以改成下面的代碼。

function fun1() {

    return fun2(); // 這里的 await 為什么可以省略?加上await結果也是一樣的

}


function fun2() {

    return fun3(); // 這里的 await 為什么可以省略?加上await結果也是一樣的

}


function fun3() {

    return new Promise(resolve => {

        console.log('fun3');

        resolve('fufff 3 ret');

    });

}


async function testfun1() {

    const ret = await fun1();

    console.log(ret);

}


testfun1()

對比下面的例子,可能更直觀


function bar () {

    return new Promise((resolve, reject) => {

        setTimeout(() => {

            resolve('bar');

        }, 1000);

    });

}


async function foo () {

    let ret1 = bar();

    let ret2 = await bar();

    console.log(ret1); // Promise { 'bar' }

    console.log(ret2); // bar

}


foo();


查看完整回答
反對 回復 2019-04-03
  • 1 回答
  • 0 關注
  • 556 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號