亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

webpack源碼中一些精妙的方法總結(jié)

 更新時間:2022年02月11日 15:07:43   作者:花開花落花中妖  
正好最近在學(xué)習(xí)webpack的源碼,所以下面這篇文章主要給大家介紹了關(guān)于webpack源碼中一些精妙的方法的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

前言

過年這一段時間一直在研究webpack的源碼,由于過年周圍氣氛比較歡快,心態(tài)有點飄導(dǎo)致沒有沉下心來仔細研究其中的細節(jié)。經(jīng)過反思之后,靜心重新捋順webpack的源碼,這時發(fā)現(xiàn)不少巧妙的方法值得學(xué)習(xí)。這里我已經(jīng)迫不及待的跟大家分享了,希望對大家平常開發(fā)過程中有所幫助。

精妙方法

緩存函數(shù)

這個方法最精妙的地方在于將執(zhí)行結(jié)果緩存,減少函數(shù)的重復(fù)執(zhí)行以達到提升性能的目的,對于執(zhí)行越復(fù)雜越耗時的函數(shù)收益越大。但是,不適用于動態(tài)執(zhí)行結(jié)果的函數(shù)。

    const memoize = fn => {
        let cache = false;
        let result = undefined;
        return () => {
            if (cache) {
                return result;
            } else {
                result = fn();
                cache = true;
                fn = undefined;
                return result;
            }
        };
    };

這個方法跟惰性函數(shù)有點相似,只在函數(shù)第一次調(diào)用的時候執(zhí)行,將fn()的執(zhí)行結(jié)果緩存到result上,然后通過cache設(shè)置為true來標記緩存已開啟。這里還有個細節(jié)值得學(xué)習(xí):由于閉包的原因,fn方法被新的函數(shù)持有,一直在調(diào)用棧中得不到釋放,而在代碼中有一句fn = undefined,手動釋放內(nèi)存。

屬性劫持

這個方法通過自定義get方法或者value值來重定義obj的屬性。實現(xiàn)的結(jié)果有點類似于Object.freeze,但又不完全相同。通過Object.defineProperty定義name的get屬性描述符來保證obj的值永遠不變;通過Object.defineProperty來將name的writable設(shè)置為false來保證obj的value不會被改變。

    const mergeExports = (obj, exports) => {
        ...
        for (const name of Object.keys(descriptors)) {
            const descriptor = descriptors[name];
            if (descriptor.get) {
                const fn = descriptor.get;
                Object.defineProperty(obj, name, {
                    configurable: false,
                    enumerable: true,
                    get: memoize(fn)
                });
            } else if (typeof descriptor.value === "object") {
                Object.defineProperty(obj, name, {
                    configurable: false,
                    enumerable: true,
                    writable: false,
                    value: mergeExports({}, descriptor.value)
                });
            } else {
                ...
            }
        }
        return Object.freeze(obj);
    };

這里還有個小的知識點:通過將屬性的configurable屬性描述符設(shè)置為false來保證屬性不可被刪除

數(shù)組比較

進行兩個數(shù)組是否相等的比較。想必大家都知道,如果使用==進行數(shù)組比較的話,是進行引用地址的比較,所以想要判斷兩個數(shù)組是沒有方法進行直接比較的。而webpack源碼中的這個方法給我提供了一種數(shù)組比較的方式。當然了,這個方法只適用于扁平化的一維基本類型數(shù)組,如果想要比較復(fù)雜的情況的話,需要在for循環(huán)的基礎(chǔ)上稍加改造。

    exports.equals = (a, b) => {
        if (a.length !== b.length) return false;
        for (let i = 0; i < a.length; i++) {
            if (a[i] !== b[i]) return false;
        }
        return true;
    };

配置項校驗

webpack中的實現(xiàn)的代碼量比較多,我們就只說一下大體實現(xiàn)思路,通過定義需要校驗的所有配置項的Schema校驗規(guī)則。大體Schema格式如下:

    "Amd": {
        "description": "Set the value of `require.amd` and `define.amd`. Or disable AMD support.",
        "anyOf": [
            {
                "description": "You can pass `false` to disable AMD support.",
                "enum": [false]
            },
            {
                "description": "You can pass an object to set the value of `require.amd` and `define.amd`.",
                "type": "object"
            }
        ]
    },

其中key對應(yīng)的是需要校驗的配置項,value中的desciption對應(yīng)的是提示信息,其余部分對應(yīng)的是校驗規(guī)則。

結(jié)尾

到此這篇關(guān)于webpack源碼中一些精妙的方法的文章就介紹到這了,更多相關(guān)webpack源碼的精妙方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 原生JS實現(xiàn)前端本地文件上傳

    原生JS實現(xiàn)前端本地文件上傳

    這篇文章主要為大家詳細介紹了原生JS實現(xiàn)前端本地文件上傳,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • Google 爬蟲如何抓取 JavaScript 的內(nèi)容

    Google 爬蟲如何抓取 JavaScript 的內(nèi)容

    我們測試了谷歌爬蟲是如何抓取 JavaScript,下面就是我們從中學(xué)習(xí)到的知識,需要的朋友可以參考下
    2017-04-04
  • JS簡單生成隨機數(shù)(隨機密碼)的方法

    JS簡單生成隨機數(shù)(隨機密碼)的方法

    這篇文章主要介紹了JS簡單生成隨機數(shù)(隨機密碼)的方法,簡單分析了javascript隨機數(shù)相關(guān)函數(shù)并結(jié)合具體實例形式分析了隨機數(shù)的相關(guān)生成技巧,需要的朋友可以參考下
    2017-05-05
  • JavaScript六種常見的繼承方法分享

    JavaScript六種常見的繼承方法分享

    繼承是面向?qū)ο缶幊讨械囊粋€重要概念,它允許一個對象(子類或派生類)獲取另一個對象(父類或基類)的屬性和方法,在 JavaScript 中,有多種方式可以實現(xiàn)繼承,本文將給大家介紹六種常見的JavaScript繼承方法,需要的朋友可以參考下
    2023-09-09
  • 阻止子元素繼承父元素事件具體思路及實現(xiàn)

    阻止子元素繼承父元素事件具體思路及實現(xiàn)

    想要阻止點擊#p_cont區(qū)域時觸發(fā)a事件,需要在#p_cont區(qū)域內(nèi)加入阻止事件冒泡的代碼,具體實現(xiàn)祥看本文,希望對你有所幫助
    2013-05-05
  • js用閉包遍歷樹狀數(shù)組的方法

    js用閉包遍歷樹狀數(shù)組的方法

    這篇文章主要介紹了js中用閉包遍歷樹狀數(shù)組的方法,需要的朋友可以參考下
    2014-03-03
  • 微信小程序在text文本實現(xiàn)多種字體樣式

    微信小程序在text文本實現(xiàn)多種字體樣式

    這篇文章主要介紹了微信小程序在text文本實現(xiàn)多種字體樣式,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • vant倒序年月日期組件封裝實例詳解

    vant倒序年月日期組件封裝實例詳解

    這篇文章主要介紹了vant倒序年月日期組件封裝實例詳解,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-03-03
  • 關(guān)于better-scroll插件的無法滑動bug(2021通過插件解決)

    關(guān)于better-scroll插件的無法滑動bug(2021通過插件解決)

    這篇文章主要介紹了關(guān)于better-scroll插件的無法滑動bug(2021通過插件解決),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • Javascript實現(xiàn)鼠標右鍵特色菜單

    Javascript實現(xiàn)鼠標右鍵特色菜單

    鼠標右鍵大家都經(jīng)常操作,但是鼠標的內(nèi)容是不是符合大家的“口味”?這篇文章就是教大家如何定制自己專屬鼠標右鍵,需要的朋友可以參考下
    2015-08-08

最新評論