国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

webpack4 SplitChunks實現代碼分隔詳解

Zachary / 1904人閱讀

摘要:代碼均放在倉庫給我們帶來了一些改變。插件以前使用允許我們將公共依賴項提取到現有的或全新的代碼塊中。代碼詳情見文章開頭倉庫。這才是配置的關鍵緩存組會繼承的配置,但是和只能用于配置緩存組。可以通過禁用緩存組。

代碼均放在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.js
var 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.js
var react = require("react");
var reactDom = require("react-dom");
var utility2 = require("../utils/utility2");
var utility3 = require("../utils/utility3");

module.exports = "pageB";
// src/pageC.js
var 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目錄

可以發現,打包出來的除了三個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目錄

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

上圖可以看出,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之后如下圖所示。

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

附錄

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

npm i webpack-bundle-analyzer -D

引入:

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

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

new BundleAnalyzerPlugin()

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/7308.html

相關文章

  • webpack4 optimization總結

    摘要:總結默認為,效果就是壓縮代碼。主要就是根據不同的策略來分割打包出來的。同時分割同步和異步代碼推薦。內部的參數可以和覆蓋外部的參數。正則匹配文件優先級是否復用存在的匹配規則重寫公用的次數重寫文件名稱強制生成文件名稱分隔符號 optimization總結 minimize 默認為true,效果就是壓縮js代碼。 minimizer 可以自定義UglifyJsPlugin和一些配置,默認的壓...

    RyanQ 評論0 收藏0
  • webpack4介紹與總結

    摘要:隨著承擔地職責越來越大,模塊化開發的需求越來越急迫。我們可以把當成是模塊化標準的實現方案,但的功能不僅限于此。支持多種模塊使用方式,包括的。下面介紹一下在工程中常用的。最后一個的輸出就是我們最終要的結果。在文件有值的情況下,是必要的。 由于web應用擴展地得極其迅猛,前端技術也是日新月異,前端的苦不是有多難學,而是我剛學完,這東西就被淘汰了(手動哭臉)。框架方面我們有vue、react...

    yanbingyun1990 評論0 收藏0
  • webpack4配置詳解之逐行分析

    摘要:今天就嘗試著一起來聊聊吧,旨在幫大家加深理解新手更容易上路,都能從到搭建配置自定屬于自己的腳手架,或對已封裝好的腳手架有進一步的鞏固,接下來蘇南會詳細講解中的每一個配置字段的作用部分為新增。 showImg(https://segmentfault.com/img/bVbjmMV?w=1008&h=298); 前言   經常會有群友問起webpack、react、redux、甚至cre...

    dkzwm 評論0 收藏0
  • 帶你了解webpack

    摘要:根據依賴關系,按照配置文件把模塊函數分組打包成若干個。會隨著自身的的修改,而發生變化。只需要在命令行運行時帶上參數就搞定一些插件的廢除和替換廢棄了頂替者用屬性變化壓縮優化代碼分割,下面詳解還有一些新的插件,。 1. 前端工程化項目打包歷史 前端工程化之前的時代略過 1. 半自動執行腳本來壓縮合并文件 自從xmlhttprequest被挖掘出來,網頁能夠和服務端通訊,js能做的事越來越多...

    senntyou 評論0 收藏0

發表評論

0條評論

Zachary

|高級講師

TA的文章

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