麻豆黑色丝袜jk制服福利网站-麻豆精品传媒视频观看-麻豆精品传媒一二三区在线视频-麻豆精选传媒4区2021-在线视频99-在线视频a

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > 如何減少 Webpack 打包體積

如何減少 Webpack 打包體積

來(lái)源:千鋒教育
發(fā)布人:wjy
時(shí)間: 2022-09-07 16:58:00 1662541080

  1. 按需加載

  在開(kāi)發(fā) SPA 項(xiàng)目的時(shí)候,項(xiàng)目中都會(huì)存在很多路由頁(yè)面。如果將這些頁(yè)面全部打包進(jìn)一個(gè) JS 文件的話,雖然將多個(gè)請(qǐng)求合并了,但是同樣也加載了很多并不需要的代碼,耗費(fèi)了更長(zhǎng)的時(shí)間。那么為了首頁(yè)能更快地呈現(xiàn)給用戶,希望首頁(yè)能加載的文件體積越小越好,這時(shí)候就可以使用按需加載,將每個(gè)路由頁(yè)面單獨(dú)打包為一個(gè)文件。當(dāng)然不僅僅路由可以按需加載,對(duì)于 loadash 這種大型類庫(kù)同樣可以使用這個(gè)功能。

  按需加載的代碼實(shí)現(xiàn)這里就不詳細(xì)展開(kāi)了,因?yàn)殍b于用的框架不同,實(shí)現(xiàn)起來(lái)都是不一樣的。當(dāng)然了,雖然他們的用法可能不同,但是底層的機(jī)制都是一樣的。都是當(dāng)使用的時(shí)候再去下載對(duì)應(yīng)文件,返回一個(gè) Promise,當(dāng) Promise 成功以后去執(zhí)行回調(diào)。

  2. Scope Hoisting

  Scope Hoisting 會(huì)分析出模塊之間的依賴關(guān)系,盡可能的把打包出來(lái)的模塊合并到一個(gè)函數(shù)中去。

  比如希望打包兩個(gè)文件:

  

 

  對(duì)于這種情況,打包出來(lái)的代碼會(huì)類似這樣:

  

 

  但是如果使用 Scope Hoisting ,代碼就會(huì)盡可能的合并到一個(gè)函數(shù)中去,也就變成了這樣的類似代碼:

  

 

  這樣的打包方式生成的代碼明顯比之前的少多了。如果在 Webpack4 中你希望開(kāi)啟這個(gè)功能,只需要啟用 optimization.concatenateModules 就可以了:

  

 

  3. Tree Shaking

  Tree Shaking 可以實(shí)現(xiàn)刪除項(xiàng)目中未被引用的代碼,比如:

  

 

  對(duì)于以上情況,test 文件中的變量 b 如果沒(méi)有在項(xiàng)目中使用到的話,就不會(huì)被打包到文件中。

  如果使用 Webpack 4 的話,開(kāi)啟生產(chǎn)環(huán)境就會(huì)自動(dòng)啟動(dòng)這個(gè)優(yōu)化功能。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
軟件定制開(kāi)發(fā)中的敏捷開(kāi)發(fā)是什么?

軟件定制開(kāi)發(fā)中的敏捷開(kāi)發(fā)是什么軟件定制開(kāi)發(fā)中的敏捷開(kāi)發(fā),從宏觀上看,是一個(gè)高度關(guān)注人員交互,持續(xù)開(kāi)發(fā)與交付,接受需求變更并適應(yīng)環(huán)境變化...詳情>>

2023-10-14 13:24:57
什么是PlatformIo?

PlatformIO是什么PlatformIO是一個(gè)全面的物聯(lián)網(wǎng)開(kāi)發(fā)平臺(tái),它為眾多硬件平臺(tái)和開(kāi)發(fā)環(huán)境提供了統(tǒng)一的工作流程,有效簡(jiǎn)化了開(kāi)發(fā)過(guò)程,并能兼容各種...詳情>>

2023-10-14 12:55:06
云快照與自動(dòng)備份有什么區(qū)別?

1、定義和目標(biāo)不同云快照的主要目標(biāo)是提供一種快速恢復(fù)數(shù)據(jù)的方法,它只記錄在快照時(shí)間點(diǎn)后的數(shù)據(jù)變化,而不是所有的數(shù)據(jù)。自動(dòng)備份的主要目標(biāo)...詳情>>

2023-10-14 12:48:59
服務(wù)器為什么要用Linux?

服務(wù)器為什么要用Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,Linux在眾多選擇中脫穎而出。Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,有其獨(dú)特的優(yōu)勢(shì)和特點(diǎn)。包括其...詳情>>

2023-10-14 12:34:11
ORM解決的主要問(wèn)題是什么?

ORM(對(duì)象關(guān)系映射)解決的主要問(wèn)題是將關(guān)系數(shù)據(jù)庫(kù)與面向?qū)ο缶幊讨g的映射困境。在傳統(tǒng)的關(guān)系數(shù)據(jù)庫(kù)中,數(shù)據(jù)以表格的形式存儲(chǔ),而在面向?qū)ο?..詳情>>

2023-10-14 12:26:19
快速通道
主站蜘蛛池模板: 欧美怡红院免费全视频| 亚洲二区电影| 女人18毛片a级毛片| 渣男渣女抹胸渣男渣女app| 五月婷婷电影网| 人体大胆做受免费视频| 女大学生沙龙室3| 国产精品区免费视频| 看了流水的小说| 啊v在线观看| 天天躁日日躁狠狠躁| 公洗澡时强要了| 久久久久久久性潮| 久爱视频在线| 国产v在线播放| 公交车上被弄进走不动| 超清高清欧美videos| 美女pk精子| 窈窕淑女韩国在线看| 鲁啊鲁在线视频| 天天舔天天色| 中文字幕在线视频网站| 美女被网站大全在线视频| 狠狠色噜噜狠狠狠合久| 女人把私密部位张开让男人桶| 里番肉本子同人全彩h| 泰国午夜理伦三级| 欧美特黄色片| 精品在线一区二区| 国产乱码精品一区二区三区四川人 | 亚洲欧美国产另类视频| 中文字幕第9页萱萱影音先锋| 女人被男人狂躁视频免费| 女人把私密部位张开让男人桶| 欧美激情一区二区三区蜜桃视频| 国产精品一级二级三级| 国产国产精品人在线视| 色婷婷在线视频| 日韩欧美高清在线| aaa毛片免费观看| 美女扒开尿口让男人桶进|