webpack 代碼分片

代碼分離

大型的web項(xiàng)目捷绒,將所有的代碼放到一個(gè)文件的做法效率很差,尤其是加載一些特定環(huán)境才會(huì)使用的代碼瘩扼。
webpack可以把代碼分離成chunk焚碌,不僅可以按需打包/按需加載,還可以實(shí)現(xiàn)提取公共代碼梦鉴。

定義分離點(diǎn)

AMD和CommonJs需要不同的方式來實(shí)現(xiàn)按需加載李茫,webpack通過定義分離點(diǎn)的方式,對(duì)兩者都支持肥橙。

CommonJs require.ensure(dependencies, callback)

dependencies會(huì)在調(diào)用callback時(shí)被同步的請(qǐng)求過來魄宏。
require作為實(shí)參傳入到callback函數(shù)。
require.ensure僅加載模塊存筏,不執(zhí)行

require.ensure(
    ["module-a", "module-b"],
    function(require) {
        var a = require("module-a");
        // ...
    }
);

AMD require(dependencies, callback)

加載dependencies宠互,并把他們作為實(shí)參傳入callback
require加載并執(zhí)行模塊塔次,自左而右,callback可以為空

require(
    ['module-a', 'module-b'],
    function(a, b) {
        // ...
    }
);

分離點(diǎn)的所有模塊都會(huì)被獨(dú)立成一個(gè)分塊名秀,依賴會(huì)被遞歸添加励负。如果分離點(diǎn)的callback是一個(gè)函數(shù),webpack會(huì)把該函數(shù)里的依賴都提取到按需加載的代碼塊中匕得。

  • 如果分塊包含的模塊完全一致继榆,那么這兩個(gè)模塊會(huì)被合并成一個(gè),這意味著分塊可能被多個(gè)父模塊引用汁掠。
  • 如果一個(gè)模塊在一個(gè)分塊的所有父模塊中可用略吨,那么它將會(huì)從該分塊中移除。
  • 如果一個(gè)分塊包含了另一個(gè)分塊的所有模塊考阱,它將會(huì)被保存起來翠忠。

分塊類型

入口塊 entry chunk

一個(gè)入口塊包含運(yùn)行時(shí)和一系列模塊,如果一個(gè)入口塊包含了模塊0乞榨,那么運(yùn)行時(shí)將會(huì)執(zhí)行這個(gè)模塊秽之,如果沒包含,那么將會(huì)等待包含了模塊0的分塊吃既,然后執(zhí)行

普通塊 normal chunk

一個(gè)普通塊包含一系列模塊考榨,而不包含運(yùn)行時(shí)。

初始?jí)K initial chunk

一個(gè)初始?jí)K是一個(gè)普通的分塊鹦倚,不同的是會(huì)做特別優(yōu)化河质,因?yàn)檫@關(guān)系到首次加載時(shí)間的長短。這種分塊可以結(jié)合CommonChunksPlugin來生成

多入口塊

每個(gè)入口塊都應(yīng)該包含運(yùn)行時(shí)震叙,但一個(gè)頁面只能有一個(gè)運(yùn)行時(shí)掀鹅,通過CommonsChunkPlugin可以解決這個(gè)問題。
使用CommonsChunkPlugin后媒楼,運(yùn)行時(shí)會(huì)被移到公共分塊中乐尊,從而可以在同一個(gè)頁面使用多個(gè)入口塊。

{
    entry: { a: "./a", b: "./b" },
    output: { filename: "[name].js" },
    plugins: [new webpack.optimize.CommonsChunkPlugin("init.js")]
}

<script src="init.js"></script>
<script src="a.js"></script>
<script src="b.js"></script>

擴(kuò)展問題

公共塊

使用 CommonsChunkPlugin使用把多個(gè)入口塊的公共模塊移到一個(gè)新的入口塊(公共塊)同時(shí)也會(huì)把運(yùn)行時(shí)移到公共塊匣砖,這意味著原始入口塊變成了初始?jí)K

優(yōu)化

根據(jù)具體的場(chǎng)景使用不同的優(yōu)化插件來合并分塊

  • LimitChunkCountPlugin
  • MinChunkSizePlugin
  • AggressiveMergingPlugin
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末科吭,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子猴鲫,更是在濱河造成了極大的恐慌对人,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,185評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件拂共,死亡現(xiàn)場(chǎng)離奇詭異牺弄,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)宜狐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門势告,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蛇捌,“玉大人,你說我怎么就攤上這事咱台÷绨瑁” “怎么了?”我有些...
    開封第一講書人閱讀 163,524評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵回溺,是天一觀的道長春贸。 經(jīng)常有香客問我,道長遗遵,這世上最難降的妖魔是什么萍恕? 我笑而不...
    開封第一講書人閱讀 58,339評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮车要,結(jié)果婚禮上允粤,老公的妹妹穿的比我還像新娘。我一直安慰自己翼岁,他們只是感情好类垫,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,387評(píng)論 6 391
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著登澜,像睡著了一般阔挠。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上脑蠕,一...
    開封第一講書人閱讀 51,287評(píng)論 1 301
  • 那天,我揣著相機(jī)與錄音跪削,去河邊找鬼谴仙。 笑死,一個(gè)胖子當(dāng)著我的面吹牛碾盐,可吹牛的內(nèi)容都是我干的晃跺。 我是一名探鬼主播,決...
    沈念sama閱讀 40,130評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼毫玖,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼掀虎!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起付枫,我...
    開封第一講書人閱讀 38,985評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤烹玉,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后阐滩,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體二打,經(jīng)...
    沈念sama閱讀 45,420評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,617評(píng)論 3 334
  • 正文 我和宋清朗相戀三年掂榔,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了继效。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片症杏。...
    茶點(diǎn)故事閱讀 39,779評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖瑞信,靈堂內(nèi)的尸體忽然破棺而出厉颤,到底是詐尸還是另有隱情,我是刑警寧澤凡简,帶...
    沈念sama閱讀 35,477評(píng)論 5 345
  • 正文 年R本政府宣布逼友,位于F島的核電站,受9級(jí)特大地震影響潘鲫,放射性物質(zhì)發(fā)生泄漏翁逞。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,088評(píng)論 3 328
  • 文/蒙蒙 一溉仑、第九天 我趴在偏房一處隱蔽的房頂上張望挖函。 院中可真熱鬧,春花似錦浊竟、人聲如沸怨喘。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽必怜。三九已至,卻和暖如春后频,著一層夾襖步出監(jiān)牢的瞬間梳庆,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評(píng)論 1 269
  • 我被黑心中介騙來泰國打工卑惜, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留膏执,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,876評(píng)論 2 370
  • 正文 我出身青樓露久,卻偏偏與公主長得像更米,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子毫痕,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,700評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容