成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

async await詳解

KavenFan / 2840人閱讀

摘要:本身就是的語法糖。類似于后面代碼會等內(nèi)部代碼全部完成后再執(zhí)行打印結果操作符用于等待一個對象。它只能在異步函數(shù)中使用。參考附在版本位中是可以直接使用的。持續(xù)更新中來點顆吧

async await本身就是promise + generator的語法糖。

本文主要講述以下內(nèi)容

async awiat 實質

async await 主要特性

async await 實質

下面使用 promise + generate 實現(xiàn) async await

    // 轉換目標 async1
    // async function async1() {
    //    console.log("async1 start");
    //    await async2();
    //    console.log("async1 end");
    // }

    function async1() {
        // 將 async 轉換成 *,將 awiat 轉換成 yield
        var awaitInstance = (function* () {
            console.log("async1 start");
            yield async2();
            console.log("async1 end");
        })()

        // 自動執(zhí)行 await 及后續(xù)代碼
        // 簡單起見,不處理異常情況
        function step() {
            var next = awaitInstance.next();
            // 使用Promise獲取 異步/同步 方法的結果,再執(zhí)行下一步
            Promise.resolve(next.value).then(function (val) {
                if (!next.done) step();
            })
        }
        step();

        // 返回Promise
        return Promise.resolve(undefined);
    }
async await 特性

async 一定會返回 promise

    // 案例1: 不設置return
    async function fn() {}
    fn().then(alert); // alert -> undefined

    // 案例2:return非promise
    async function f() {
        return 1
    }
    f().then(alert); // alert -> 1

    // 案例3: return Promise
    async function fn() {
        return Promise.resolve(2);
    }
    fn().then(alert); // alert -> 2

async 中代碼是直接執(zhí)行的(同步任務)

    console.log(1);

    async function fn() {
        console.log(2);
        await console.log(3)
        console.log(4)
     }
    fn();

    console.log(5);

    // 打印 1 2 3 5 4
    // 為何后面是 3 5 4 ? 往下看

await是直接執(zhí)行的,而await后面的代碼是 microtask。

    async function async1() {
        console.log("async1 start");
        await async2();
        console.log("async1 end");
    }

    // 類似于
    async function async1() {
        console.log("async1 start");
        Promise.resolve(async2()).then(() => {
            console.log("async1 end");
        })
    }

await后面代碼會等await內(nèi)部代碼全部完成后再執(zhí)行

    async function async1() {
        console.log("async1 start");
        await async2();
        console.log("async1 end");
    }

    async function async2() {
        return new Promise(function(resolve) {
            setTimeout(function() {
                console.log("sleep 2s");
                resolve("do");
            }, 2000)
        })
    }

    async1();

    // 打印結果
    // async1 start -> sleep 2s -> async1 end

await 操作符用于等待一個Promise 對象。它只能在異步函數(shù) async function 中使用。參考 MDN

    附:
    在chrome版本 73.0.3683.86(64 位)中,
    await是可以直接使用的。

    var x = await console.log(1)
End
持續(xù)更新中 來Github 點顆?吧

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/116055.html

相關文章

  • async await詳解

    摘要:本身就是的語法糖。類似于后面代碼會等內(nèi)部代碼全部完成后再執(zhí)行打印結果操作符用于等待一個對象。它只能在異步函數(shù)中使用。參考附在版本位中是可以直接使用的。持續(xù)更新中來點顆吧 async await本身就是promise + generator的語法糖。 本文主要講述以下內(nèi)容 async awiat 實質 async await 主要特性 async await 實質 下面使用 pro...

    Shimmer 評論0 收藏0
  • async await詳解

    摘要:本身就是的語法糖。類似于后面代碼會等內(nèi)部代碼全部完成后再執(zhí)行打印結果操作符用于等待一個對象。它只能在異步函數(shù)中使用。參考附在版本位中是可以直接使用的。持續(xù)更新中來點顆吧 async await本身就是promise + generator的語法糖。 本文主要講述以下內(nèi)容 async awiat 實質 async await 主要特性 async await 實質 下面使用 pro...

    yedf 評論0 收藏0
  • async/await 執(zhí)行順序詳解

    摘要:怎么處理返回值輸出結果從結果中可以看到函數(shù)返回的是一個對象,如果在函數(shù)中一個直接量,會把這個直接量通過封裝成對象。如果函數(shù)沒有返回值結果結果返回。 隨著async/await正式納入ES7標準,越來越多的人開始研究據(jù)說是異步編程終級解決方案的 async/await。但是很多人對這個方法中內(nèi)部怎么執(zhí)行的還不是很了解,本文是我看了一遍技術博客理解 JavaScript 的 async/a...

    derek_334892 評論0 收藏0
  • async、await詳解

    摘要:異步函數(shù)是和的組合,基本上,它們是對的更高級別的抽象。引入的原因它們降低了對一些固定語法樣板的要求,打破了鏈式不能切斷鏈式的限制。引入來解決著名的回調地獄問題,但是因為他們自身的復雜性,引入了更復雜的語法。 1、簡介 需先了解 Promise 【鏈接地址】 JavaScript 中的異步函數(shù)方法。 JavaScript 在很短的時間內(nèi)從回調演變?yōu)?Promises ,從 ES2...

    Simon_Zhou 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<