亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

webpack4 SplitChunks實現代碼分隔詳解

2024-05-06 16:51:18
字體:
來源:轉載
供稿:網友

代碼均放在 git倉庫

Webpack 4給我們帶來了一些改變。包括更快的打包速度,引入了SplitChunksPlugin插件來取代(之前版本里的)CommonsChunksPlugin插件。在這篇文章中,你將學習如何分割你的輸出代碼,從而提升我們應用的性能。

SplitChunks插件( webpack 4.x以前使用CommonsChunkPlugin )允許我們將公共依賴項提取到現有的 entry chunk 或全新的代碼塊中。

代碼分割的理念

首先搞明白: webpack里的代碼分割是個什么鬼? 它允許你將一個文件分割成多個文件。如果使用的好,它能大幅提升你的應用的性能。其原因是基于瀏覽器會緩存你的代碼這一事實。每當你對某一文件做點改變,訪問你站點的人們就要重新下載它。然而依賴卻很少變動。如果你將(這些依賴)分離成單獨的文件,訪問者就無需多次重復下載它們了。

使用webpack生成一個或多個包含你源代碼最終版本的“打包好的文件”(bundles),(概念上我們當作)它們由(一個一個的)chunks組成。

首先 webpack 總共提供了三種辦法來實現 Code Splitting,如下:

  • 入口配置:entry 入口使用多個入口文件;
  • 抽取公有代碼:使用 SplitChunks 抽取公有代碼;
  • 動態加載 :動態加載一些代碼。

這里我們姑且只討論使用 SplitChunks 抽取公有代碼。

splitChunks配置

在src目錄下創建三個文件pageA.js、pageB.js和pageC.js。代碼詳情見文章開頭git倉庫。

// src/pageA.jsvar react = require('react');var reactDom = require('react-dom');var utility1 = require('../utils/utility1');var utility2 = require('../utils/utility2');new Vue();module.exports = "pageA";
// src/pageB.jsvar react = require('react');var reactDom = require('react-dom');var utility2 = require('../utils/utility2');var utility3 = require('../utils/utility3');module.exports = "pageB";
// src/pageC.jsvar react = require('react');var reactDom = require('react-dom');var utility2 = require('../utils/utility2');var utility3 = require('../utils/utility3');module.exports = "pageC";

入口文件 && 出口文件

entry: { pageA: "./src/pageA", // 引用utility1.js utility2.js pageB: "./src/pageB", // 引用utility2.js utility3.js pageC: "./src/pageC", // 引用utility2.js utility3.js},output: { path: path.join(__dirname, "dist"), filename: "[name].[hash:8].bundle.js"},

配置optimization

首先我們配置optimization如下:

optimization: { splitChunks: {  chunks: "all", },

執行npm run build打包命令之后,查看dist目錄

webpack4,SplitChunks,代碼分隔

可以發現,打包出來的除了三個page文件,還存在一個vendors~pageA~pageB~pageC.[hash].bundle.js文件( 此文件中保存了pageA、pageB、pageC和node_modules中共有的size大于30KB的文件 )。事實上這全靠了配置中本身默認固有一個cacheGroups的配置項:

splitChunks: { chunks: "all", cacheGroups: {  vendors: {  test: /[///]node_modules[///]/, // 匹配node_modules目錄下的文件  priority: -10 // 優先級配置項  },  default: {  minChunks: 2,  priority: -20, // 優先級配置項  reuseExistingChunk: true  } } }

在默認設置中,會將 node_mudules 文件夾中的模塊打包進一個叫 vendors的bundle中,所有引用超過兩次的模塊分配到 default bundle 中。更可以通過 priority 來設置優先級。

參數說明如下:

  • chunks:表示從哪些chunks里面抽取代碼,除了三個可選字符串值 initial、async、all 之外,還可以通過函數來過濾所需的 chunks;
  • minSize:表示抽取出來的文件在壓縮前的最小大小,默認為 30000;
  • maxSize:表示抽取出來的文件在壓縮前的最大大小,默認為 0,表示不限制最大大??;
  • minChunks:表示被引用次數,默認為1;上述配置commons中minChunks為2,表示將被多次引用的代碼抽離成commons。

值得注意的是,如果沒有修改minSize屬性的話,而且被公用的代碼(假設是utilities.js)size小于30KB的話,它就不會分割成一個單獨的文件。在真實情形下,這是合理的,因為(如分割)并不能帶來性能確實的提升,反而使得瀏覽器多了一次對utilities.js的請求,而這個utilities.js又是如此之小(不劃算)。

  • maxAsyncRequests:最大的按需(異步)加載次數,默認為 5;
  • maxInitialRequests:最大的初始化加載次數,默認為 3;
  • automaticNameDelimiter:抽取出來的文件的自動生成名字的分割符,默認為 ~;
  • name:抽取出來文件的名字,默認為 true,表示自動生成文件名;
  • cacheGroups: 緩存組。(這才是配置的關鍵)

緩存組會繼承splitChunks的配置,但是 test、priorty和reuseExistingChunk只能用于配置緩存組 。cacheGroups是一個對象,按上述介紹的鍵值對方式來配置即可,值代表對應的選項。除此之外,所有上面列出的選擇都是可以用在緩存組里的:chunks, minSize, minChunks, maxAsyncRequests, maxInitialRequests, name。可以通過optimization.splitChunks.cacheGroups.default: false禁用default緩存組。 默認緩存組的優先級(priotity)是負數,因此所有自定義緩存組都可以有比它更高優先級(譯注:更高優先級的緩存組可以優先打包所選擇的模塊)(默認自定義緩存組優先級為0)

現在我們再重新來看一下pageA、pageB、pageC三個js文件,這三個文件中都引入了utility2.js文件,但是此文件size很明顯小于30KB,所以這部分公用代碼并沒有分割出來。如果想要分割出來很簡單,只需要:

optimization: { splitChunks: {  chunks: "all",  minSize: 0 },

執行npm run build打包命令之后,查看dist目錄

webpack4,SplitChunks,代碼分隔

顯然多了一個pageA~pageB~pageC.[hash].bundle.js文件。查看文件可得知此文件中存儲了utility2.js中的代碼。如下圖所示(借助于webpack-bundle-analyzer插件,詳情文章末尾附錄)。

webpack4,SplitChunks,代碼分隔

上圖可以看出,React相關代碼均放在了vendors~pageA~pageB~pageC.[hash].bundle.js文件中,如果我們想要抽離出React代碼,應該怎么做吶?

splitChunks: {  chunks: "all",  cacheGroups: {  commons: {   chunks: "initial",   minChunks: 2,   name: "commons",   maxInitialRequests: 5,   minSize: 0, // 默認是30kb,minSize設置為0之后       // 多次引用的utility1.js和utility2.js會被壓縮到commons中  },  reactBase: {   test: (module) => {   return /react|redux|prop-types/.test(module.context);   }, // 直接使用 test 來做路徑匹配,抽離react相關代碼   chunks: "initial",   name: "reactBase",   priority: 10,  }  } },

run build之后如下圖所示。

webpack4,SplitChunks,代碼分隔

看似非常完美,但是reactBase文件中竟然包含了node_modules,神奇的問題?室友都睡覺了,這鍵盤聲影響不好,明天接著看。

附錄

我們再安裝一個 webpack-bundle-analyzer,這個插件會清晰的展示出打包后的各個bundle所依賴的模塊:

npm i webpack-bundle-analyzer -D

引入:

const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin

使用,在plugins數組中添加即可:

new BundleAnalyzerPlugin()

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97精品视频在线| 疯狂做受xxxx高潮欧美日本| 亚洲第一中文字幕在线观看| 日韩天堂在线视频| 国产精品久久久久久久久久ktv| 青草青草久热精品视频在线观看| 亚洲美女动态图120秒| 欧美肥老太性生活视频| 日韩在线观看免费全| 久久国产精品久久久久久久久久| 日韩精品视频在线观看免费| 亚洲精品电影网在线观看| 精品国产一区二区三区在线观看| 日韩精品免费综合视频在线播放| 亚洲自拍欧美色图| 91久久久久久久久久久久久| 97在线免费观看| 国产在线精品成人一区二区三区| 久久精品国产99国产精品澳门| 97在线免费观看视频| 精品性高朝久久久久久久| 国产精品96久久久久久又黄又硬| 日av在线播放中文不卡| 久久色精品视频| 国产精品极品美女在线观看免费| 欧美精品少妇videofree| 国产精品久久久精品| 81精品国产乱码久久久久久| 欧美高清性猛交| 国产成人一区二区三区| 亚洲另类图片色| 亚洲电影天堂av| 91精品久久久久久久久不口人| 国产亚洲精品激情久久| 国内精品视频久久| 国产一区二区在线免费视频| 色噜噜久久综合伊人一本| 91超碰中文字幕久久精品| 欧美另类精品xxxx孕妇| 中文字幕亚洲欧美日韩高清| 久久国产精品久久国产精品| 尤物99国产成人精品视频| 成人精品视频99在线观看免费| 国内精品一区二区三区四区| 91中文字幕一区| 亚洲人午夜色婷婷| 欧美在线视频导航| 欧美日韩在线第一页| 精品视频在线观看日韩| 国产欧美韩国高清| 91精品免费久久久久久久久| 日韩欧美成人区| 亚洲va欧美va在线观看| 成人h猎奇视频网站| 国模精品一区二区三区色天香| 亚洲小视频在线观看| 欧美一区视频在线| 欧美性猛交xxxx乱大交蜜桃| 欧美视频免费在线观看| 91久久在线观看| 2023亚洲男人天堂| 亚洲电影免费在线观看| 日韩在线免费观看视频| 亚洲天堂开心观看| 日韩黄色高清视频| 亚洲热线99精品视频| 精品无人区太爽高潮在线播放| 欧美激情国产高清| 97精品视频在线| 欧美性猛交视频| 亚洲丝袜在线视频| 久久精品久久久久久国产 免费| 国产一区二区三区高清在线观看| 亚洲欧美一区二区激情| 欧美孕妇与黑人孕交| 日韩欧美国产成人| 国产日韩欧美夫妻视频在线观看| 欧美成人合集magnet| 欧美日产国产成人免费图片| 欧美激情精品久久久久久黑人| 国产精自产拍久久久久久| 中文字幕无线精品亚洲乱码一区| 中文字幕亚洲欧美日韩2019| 亚洲成人黄色网址| 亚洲精品456在线播放狼人| 欧美在线视频一区| 亚洲在线免费视频| 欧美亚洲成人xxx| 国产精品亚洲精品| 国产在线高清精品| 午夜精品久久久久久久99热| 国产欧美在线看| 这里只有精品视频| 久久99久久99精品中文字幕| 国产精品96久久久久久| 亚洲成人精品视频| 中文在线不卡视频| 国产精品一区=区| www.久久久久| 国产精品久久久久久久久久99| 欧美黑人视频一区| 久久久久久久久久国产精品| 国产97在线|日韩| 伊人亚洲福利一区二区三区| 日韩高清中文字幕| 欧美主播福利视频| 久久久久久国产精品久久| 亚洲精品久久久久中文字幕欢迎你| 日韩av中文字幕在线免费观看| 亚洲国产成人爱av在线播放| 亚洲欧洲一区二区三区久久| 国产精品视频精品视频| 国产精品69精品一区二区三区| 大伊人狠狠躁夜夜躁av一区| 亚洲激情久久久| 久久成人国产精品| 精品电影在线观看| 91久久久久久久| 97视频在线观看播放| 日韩在线观看免费全| 黄色成人在线免费| 91精品国产乱码久久久久久蜜臀| 奇米成人av国产一区二区三区| 97超级碰碰碰| 92国产精品久久久久首页| 色偷偷亚洲男人天堂| 日韩视频在线观看免费| 最近2019中文字幕一页二页| 日韩黄色av网站| 97在线视频精品| 疯狂做受xxxx高潮欧美日本| 亚洲国产精品va在线看黑人| 国产v综合v亚洲欧美久久| 欧美国产第一页| 久久人人爽人人爽人人片av高请| 欧美性xxxxxxxxx| 亚洲电影免费观看高清完整版在线观看| 国产精品夜色7777狼人| 欧美性视频在线| 久久综合伊人77777| 91地址最新发布| 美日韩精品免费观看视频| 亚洲第一精品电影| 久久久国产精品x99av| 国产精品久久婷婷六月丁香| 97在线看福利| 中文字幕精品一区二区精品| 色噜噜狠狠色综合网图区| 91精品在线影院| 精品国产一区二区三区四区在线观看| 亚洲一品av免费观看| 欧美电影免费观看| 国产精品91免费在线| 亚洲男人天堂网| 亚洲欧美综合精品久久成人| 亚洲男人第一网站| 日韩亚洲欧美成人| 久久国产视频网站| 最近2019年手机中文字幕| 亚洲欧美日韩在线高清直播| 久久久久久91香蕉国产| 日韩欧美aaa| 欧美视频在线观看免费网址| 亚洲国产精品人久久电影|