国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

es6 promise源碼實(shí)現(xiàn)

未東興 / 1064人閱讀

摘要:執(zhí)行的時(shí)候呢即可如何處理鏈?zhǔn)降那冶WC順序每個(gè)后面鏈一個(gè)對(duì)象該對(duì)象包含子三個(gè)屬性當(dāng)父狀態(tài)改變完畢執(zhí)行完相應(yīng)的的時(shí)候呢,拿到子在等待這個(gè)子狀態(tài)改變,在執(zhí)行相應(yīng)的。

promise源碼分析 初級(jí)入門以及如何使用請(qǐng)看 阮一峰promise對(duì)象講解 先上一坨代碼,后面我們要基于這坨代碼來(lái)實(shí)現(xiàn)自定義promise 原始方法
setTimeout(function(){
    var a=100;
    console.log(a);
    setTimeout(function () {
        var b=200;
        console.log(b)
        setTimeout(function () {
            var c=300;
            console.log(c)
        }, 1000);
    }, 1000);
},1000);   
promise實(shí)現(xiàn)
 new Promise(function (resolve, reject) {
    setTimeout(function () {
        var a=100;
        resolve(a);
    }, 1000);
}).then(function (res) {
    console.log(res);
    return new Promise(function (resolve, reject) {
        setTimeout(function () {
            var b=200;
            resolve(b);
        }, 1000);
    })
}).then(function (res) {
    console.log(res);
    return new Promise(function (resolve, reject) {
        setTimeout(function () {
            var c=300
            resolve(c);
        }, 1000);
    })
}).then(function (res) {
        console.log(res);
    }
    )
如何讓你的promise能有此魔力

讓a,b,c的值能在then里面的回調(diào)接收到

在連續(xù)調(diào)用異步,如何確保異步函數(shù)的執(zhí)行順序

如何讓異步的value在thenable函數(shù)中拿到

將resolve/reject函數(shù)和onfulfiled/onrejected放入同一個(gè)對(duì)象(promise對(duì)象)里面,resolve/reject的時(shí)候?qū)alue設(shè)置this.value=xxx。onfulfiled/onrejected執(zhí)行的時(shí)候呢,onfulfiled(this.value)即可

如何處理鏈?zhǔn)降膒romise且保證順序

每個(gè)promise后面鏈一個(gè)對(duì)象該對(duì)象包含onfulfiled,onfulfiled,子promise三個(gè)屬性.

當(dāng)父promise 狀態(tài)改變完畢,執(zhí)行完相應(yīng)的onfulfiled/onfulfiled的時(shí)候呢,拿到子promise,在等待這個(gè)子promise狀態(tài)改變,在執(zhí)行相應(yīng)的onfulfiled/onfulfiled。依次循環(huán)直到當(dāng)前promise沒(méi)有子promise

最終代碼(內(nèi)涵注釋)
            /*
            我們要滿足狀態(tài)只能三種狀態(tài):PENDING,FULFILLED,REJECTED三種狀態(tài),且狀態(tài)只能由PENDING=>FULFILLED,或者PENDING=>REJECTED
            */
            var PENDING = 0;
            var FULFILLED = 1;
            var REJECTED = 2;
            /*
            value狀態(tài)為執(zhí)行成功事件的入?yún)ⅲ琩eferreds保存著狀態(tài)改變之后的需要處理的函數(shù)以及promise子節(jié)點(diǎn),構(gòu)造函數(shù)里面應(yīng)該包含這三個(gè)屬性的初始化
             */
            function Promise(callback) {
                this.status = PENDING;
                this.value = null;
                this.defferd = [];
                setTimeout(callback.bind(this, this.resolve.bind(this), this.reject.bind(this)), 0);
            }
            
            Promise.prototype = {
                constructor: Promise,
                //觸發(fā)改變promise狀態(tài)到FULFILLED
                resolve: function (result) {
                    this.status = FULFILLED;
                    this.value = result;
                    this.done();
                },
                //觸發(fā)改變promise狀態(tài)到REJECTED
                reject: function (error) {
                    this.status = REJECTED;
                    this.value = error;
                },
                //處理defferd
                handle: function (fn) {
                    if (!fn) {
                        return;
                    }
                    var value = this.value;
                    var t = this.status;
                    var p;
                    if (t == PENDING) {
                         this.defferd.push(fn);
                    } else {
                        if (t == FULFILLED && typeof fn.onfulfiled == "function") {
                            p = fn.onfulfiled(value);
                        }
                        if (t == REJECTED && typeof fn.onrejected == "function") {
                            p = fn.onrejected(value);
                        }
                    var promise = fn.promise;
                    if (promise) {
                        if (p && p.constructor == Promise) {
                            p.defferd = promise.defferd;
                        } else {
                            p = this;
                            p.defferd = promise.defferd;
                            this.done();
                        }
                    }
                    }
                },
                //觸發(fā)promise defferd里面需要執(zhí)行的函數(shù)
                done: function () {
                    var status = this.status;
                    if (status == PENDING) {
                        return;
                    }
                    var defferd = this.defferd;
                    for (var i = 0; i < defferd.length; i++) {
                        this.handle(defferd[i]);
                    }
                },
                /*儲(chǔ)存then函數(shù)里面的事件
                返回promise對(duì)象
                defferd函數(shù)當(dāng)前promise對(duì)象里面
                */
                then: function (success, fail) {
                   var o = {
                        onfulfiled: success,
                        onrejected: fail
                    };
                    var status = this.status;
                    o.promise = new this.constructor(function () {
            
                    });
                    if (status == PENDING) {
                        this.defferd.push(o);
                    } else if (status == FULFILLED || status == REJECTED) {
                        this.handle(o);
                    }
                    return o.promise;
                }
            };
在附上一張手繪的流程圖

參考資料

v8官方實(shí)現(xiàn)

源碼地址

github

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

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/91619.html

相關(guān)文章

  • JavaScript 異步

    摘要:從最開(kāi)始的到封裝后的都在試圖解決異步編程過(guò)程中的問(wèn)題。為了讓編程更美好,我們就需要引入來(lái)降低異步編程的復(fù)雜性。寫一個(gè)符合規(guī)范并可配合使用的寫一個(gè)符合規(guī)范并可配合使用的理解的工作原理采用回調(diào)函數(shù)來(lái)處理異步編程。 JavaScript怎么使用循環(huán)代替(異步)遞歸 問(wèn)題描述 在開(kāi)發(fā)過(guò)程中,遇到一個(gè)需求:在系統(tǒng)初始化時(shí)通過(guò)http獲取一個(gè)第三方服務(wù)器端的列表,第三方服務(wù)器提供了一個(gè)接口,可通過(guò)...

    tuniutech 評(píng)論0 收藏0
  • promise 實(shí)現(xiàn)es6 完整源碼

    摘要:當(dāng)?shù)臓顟B(tài)已經(jīng)流轉(zhuǎn)時(shí),回調(diào)函數(shù)會(huì)立即被執(zhí)行,當(dāng)還處于狀態(tài)時(shí),回調(diào)函數(shù)被推入相應(yīng)隊(duì)列中等待執(zhí)行。 概覽 const PENDING = Symbol(PENDING); const FULFILLED = Symbol(FULFILLED); const REJECTED = Symbol(REJECTED); class MyPromise { constructor(fn) ...

    solocoder 評(píng)論0 收藏0
  • 淺析es6-promise源碼

    摘要:主要邏輯本質(zhì)上還是回調(diào)函數(shù)那一套。通過(guò)的判斷完成異步和同步的區(qū)分。 主要邏輯: 本質(zhì)上還是回調(diào)函數(shù)那一套。通過(guò)_subscribers的判斷完成異步和同步的區(qū)分。通過(guò) resolve,reject -> publish -> invokeCallback -> resolve,reject的遞歸和下一條then的parent是上一條的child來(lái)完成then鏈的流轉(zhuǎn) 同步情況...

    fox_soyoung 評(píng)論0 收藏0
  • Promise源碼學(xué)習(xí)(2)

    摘要:源碼學(xué)習(xí)本篇為上一篇源碼學(xué)習(xí)的補(bǔ)充,主要是來(lái)介紹和方法。那個(gè)率先改變的實(shí)例的返回值,就傳遞給的回調(diào)函數(shù)。基本介紹可見(jiàn)阮一峰老師的書籍。的狀態(tài)由決定,分成兩種情況。只有的狀態(tài)都變成,的狀態(tài)才會(huì)變成,此時(shí)的返回值組成一個(gè)數(shù)組,傳遞給的回調(diào)函數(shù)。 Promise源碼學(xué)習(xí)(2) 本篇為上一篇源碼學(xué)習(xí)(1)的補(bǔ)充,主要是來(lái)介紹Promise.all()和Promise.race()方法。閑話少敘...

    cfanr 評(píng)論0 收藏0
  • ES6-7

    摘要:的翻譯文檔由的維護(hù)很多人說(shuō),阮老師已經(jīng)有一本關(guān)于的書了入門,覺(jué)得看看這本書就足夠了。前端的異步解決方案之和異步編程模式在前端開(kāi)發(fā)過(guò)程中,顯得越來(lái)越重要。為了讓編程更美好,我們就需要引入來(lái)降低異步編程的復(fù)雜性。 JavaScript Promise 迷你書(中文版) 超詳細(xì)介紹promise的gitbook,看完再不會(huì)promise...... 本書的目的是以目前還在制定中的ECMASc...

    mudiyouyou 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<