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

資訊專欄INFORMATION COLUMN

webpack源碼分析之二:code-splitting

wudengzan / 3305人閱讀

摘要:前言是最引人矚目的特性之一此特性將代碼分離到不同的文件中。功能分析官網(wǎng)上有三種方式實(shí)現(xiàn)入口起點(diǎn)使用選項手動分離代碼。防止重復(fù)使用去重和分離。本質(zhì)則是多個入口的,則在以為入口文件將多入口的切分為按切割文件通過加載。

前言

code-splitting是webpack最引人矚目的特性之一,此特性將代碼分離到不同的bundle文件中。詳細(xì)介紹官網(wǎng)code-split,這次實(shí)現(xiàn)則在筆者上次文件打包之上做開發(fā)。

功能分析

官網(wǎng)上有三種方式實(shí)現(xiàn)

入口起點(diǎn):使用 entry 選項手動分離代碼。

防止重復(fù):使用 CommonsChunkPlugin 去重和分離 chunk。

動態(tài)導(dǎo)入:通過模塊的內(nèi)聯(lián)函數(shù)調(diào)用來分離代碼。

1本質(zhì)則是多個入口的chunk,2則在以common.js為入口文件,將多入口的chunk切分為按切割文件,通過jsonp加載。在這里筆者則介紹最為復(fù)雜的3的實(shí)現(xiàn),

對于webpack 的切割文件的引入本質(zhì)就是jsonp,動態(tài)引入一個約定好格式的js,并運(yùn)行。

__webpack_require__.e = function requireEnsure(chunkId) {
....
    var head = document.getElementsByTagName("head")[0];
    var script = document.createElement("script");
    script.src = __webpack_require__.p + "" + chunkId + ".bundle.js";
    head.appendChild(script);
....
}

切割文件去除注釋如下:

webpackJsonp([1],[function(){},function(){}])

而在入口文件的webpackJsonpCallback函數(shù)內(nèi),則是將切割的文件包含的modules依次放入存儲在modules內(nèi)

function webpackJsonpCallback(chunkIds, moreModules){
....
for(moduleId in moreModules) {
             if(Object.prototype.hasOwnProperty.call(moreModules, moduleId)) {
                 modules[moduleId] = moreModules[moduleId];
             }
         }
}     
....    

所以實(shí)現(xiàn)以上功能需求如下:

parse模塊:定位切割點(diǎn)并組裝異步加載文件所需要的依賴。

chunks模塊:各個chunk包含module模塊的集合,通過文件樹里面模塊的依賴關(guān)系生成。

writeChunks模塊:根據(jù)chunks,通過文件流寫入文件。

例子

require("d");

function a() {
    require.ensure(["./a"], function () {
        require("c");
    });
}

require.ensure(["./b"], function () {
    require("./m");
});

require("./e");
實(shí)現(xiàn) parse模塊

實(shí)現(xiàn)思路:

通過遞歸,以及文件樹的特征定位到require.ensure

將arguments第一個參數(shù)的數(shù)組,第二個參數(shù)的函數(shù)內(nèi)遞歸搜索require,存入數(shù)組asyncs內(nèi),并遞歸下去

數(shù)據(jù)結(jié)構(gòu)如下:

{
    filename: "/Users/zhujian/Documents/workspace/webpack/simple-webpack/example/main.js",
    id: 0,
    requires: [{
            name: "d",
            range: [8, 11],
            id: 1
        }],
    rangeRequires: [[0, 7]],
    asyncs: [{
            requires: [{
                    name: "./a",
                    id: 2
                }, {
                    name: "c",
                    range: [88, 91],
                    id: 3
                }],
            asyncs: [],
            rangeRequires: [80, 87],
            ensureRequires: [34, 58]
        },
        {
            requires: [{
                    name: "./b",
                    id: 4
                }, {
                    name: "./m",
                    range: [156, 161],
                    id: 5
                }],
            asyncs: [],
            rangeRequires: [148, 155],
            ensureRequires: [106, 130]
        }],
}
chunks模塊

由于各個依賴文件的源碼都包含在modlues內(nèi),所以chunks包含的是具體各個切割文件所包需module的moduleId。

實(shí)現(xiàn)思路:

通過入口mainPath 找到modules的入口mainModule

將mainModule 的requires遍歷,將值歸入本chunk的modules內(nèi),將asyncs遍歷,依次新建chunk,并關(guān)聯(lián)父chunk,以上兩個依次遞歸遍歷。

最終生成完了之后,將各個非根節(jié)點(diǎn)的chunk遍歷,將依賴的modules遍歷對比父節(jié)點(diǎn)的chunk,如有重復(fù)標(biāo)記"in-parent"

數(shù)據(jù)結(jié)構(gòu)如下

{ "0": 
   { id: 0,
     modules: { "0": "include", "1": "include", "2": "include" } },
  "1": 
   { id: 1,
     modules: 
      { "1": "in-parent",
        "3": "include",
        "4": "include",
        "5": "include",
        "6": "include" },
     parentId: 0 },
  "2": 
   { id: 2,
     modules: { "5": "include", "6": "include" },
     parentId: 0 
     }
}

writeChunks模塊

實(shí)現(xiàn)思路:

判斷是否有多個chunk,來區(qū)分引入的模版。如果chunks的個數(shù)超過1,入口chunk則加載包含webpackJsonp,__webpack_require__.e等支持jsonp函數(shù)的模版,未超過則加載簡單的僅包含__webpack_require__的模版

區(qū)分入口chunk,入口/非入口chunk加載不同的頭部。

webpackJsonp的入?yún)⒂袃煞N,一種數(shù)組,一種以moduleId為key的對象。為數(shù)組時候則需要將以[,,modlue]等方式保證順序

如:

代碼實(shí)現(xiàn)

本人的簡易版webpack實(shí)現(xiàn)simple-webpack

(完)

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

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/95266.html

相關(guān)文章

  • JavaScript - 收藏集 - 掘金

    摘要:插件開發(fā)前端掘金作者原文地址譯者插件是為應(yīng)用添加全局功能的一種強(qiáng)大而且簡單的方式。提供了與使用掌控異步前端掘金教你使用在行代碼內(nèi)優(yōu)雅的實(shí)現(xiàn)文件分片斷點(diǎn)續(xù)傳。 Vue.js 插件開發(fā) - 前端 - 掘金作者:Joshua Bemenderfer原文地址: creating-custom-plugins譯者:jeneser Vue.js插件是為應(yīng)用添加全局功能的一種強(qiáng)大而且簡單的方式。插....

    izhuhaodev 評論0 收藏0
  • 【回顧九月份第三周】 最近JavaScript的資訊集合

    摘要:投射劇中人物對車禍妻子偷情肇事者死亡的真相聽而不聞視而不見閉嘴不言。想方設(shè)法把自己培養(yǎng)成工程師而不是最后成為了碼農(nóng)查看更多列表回顧九月份第一周為什么你的前端工作經(jīng)驗不值錢回顧九月份第二周前端你該知道的事兒回顧九月份第三周最近的資訊集合 原鏈接:http://bluezhan.me/weekly/#/9-3 1、web前端 JavaScript實(shí)現(xiàn)H5游戲斷線自動重連的技術(shù) 前端日報:...

    iKcamp 評論0 收藏0
  • 【回顧九月份第三周】 最近JavaScript的資訊集合

    摘要:投射劇中人物對車禍妻子偷情肇事者死亡的真相聽而不聞視而不見閉嘴不言。想方設(shè)法把自己培養(yǎng)成工程師而不是最后成為了碼農(nóng)查看更多列表回顧九月份第一周為什么你的前端工作經(jīng)驗不值錢回顧九月份第二周前端你該知道的事兒回顧九月份第三周最近的資訊集合 原鏈接:http://bluezhan.me/weekly/#/9-3 1、web前端 JavaScript實(shí)現(xiàn)H5游戲斷線自動重連的技術(shù) 前端日報:...

    vvpvvp 評論0 收藏0
  • webpack源碼分析之三:loader

    摘要:本次介紹的則是用來解決這類問題的。實(shí)現(xiàn)模塊實(shí)現(xiàn)思路將配置內(nèi)的命令的的內(nèi)聯(lián)從前至后組成一個數(shù)組。所有字符串內(nèi)部又可以截取,獲取完整的。分析并解析該數(shù)組內(nèi)的字符串,獲取各個的絕對路徑。 前言 在webpack特性里面,它可以支持將非javaScript文件打包,但前面寫到webpack的模塊化打包只能應(yīng)用于含有特定規(guī)范的JavaScript文件。本次介紹的loader則是用來解決這類問題的...

    laznrbfe 評論0 收藏0

發(fā)表評論

0條評論

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