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

資訊專欄INFORMATION COLUMN

Webpack DLL 配置教程

terro / 1924人閱讀

摘要:原理文件又稱為動態(tài)鏈接庫文件,它通常作為應(yīng)用程序可執(zhí)行代碼的一部分,供應(yīng)用程序在運行時進行調(diào)用。優(yōu)化以上程序只是為了快速入手與搭建,需要優(yōu)化的地方還有很多,在此簡單的列舉幾點,供大家參考。

原理

DLL文件又稱為動態(tài)鏈接庫文件,它通常作為應(yīng)用程序可執(zhí)行代碼的一部分,供應(yīng)用程序在運行時進行調(diào)用。

在Webpack中,內(nèi)置的DllPlugin與DllReferencePlugin插件可以通過使用DLL來大幅提高構(gòu)建性能,以下是DLL機制流程圖:

初始化項目

為了便于實驗,我們通過使用create-react-app創(chuàng)建項目并eject出webpack配置:

npx create-react-app react-dll-demo
cd react-dll-demo && npm run eject

由于默認配置隱藏了編譯信息,打開webpackDevServer.config.js,將quiet: true改為false,再啟動一下項目,找出我們需要的信息:

Version: webpack 4.28.3
Time: 6985ms
Built at: 2019-02-21 10:46:42
                         Asset       Size        Chunks             Chunk Names
           asset-manifest.json  232 bytes                [emitted]
                    index.html   1.65 KiB                [emitted]
          static/js/0.chunk.js   4.21 MiB             0  [emitted]
           static/js/bundle.js   30.9 KiB  runtime~main  [emitted]  runtime~main
       static/js/main.chunk.js   47.4 KiB          main  [emitted]  main
static/media/logo.5d5d9eef.svg   2.61 KiB                [emitted]
DLLPlugin

首先在package.json的scripts字段添加一條腳本:

{
  "build:dll": "webpack --config config/webpack.dll.config.js --mode production"
}

然后創(chuàng)建配置文件:

// config/webpack.dll.config.js

const webpack = require("webpack");
const path = require("path");

module.exports = {
  entry: {
    react: ["react", "react-dom"]
  },
  output: {
    filename: "[name].dll.js",
    path: path.join(__dirname, "../public/dll"),
    libraryTarget: "var",
    library: "_dll_[name]_[hash]"
  },
  plugins: [
    new webpack.DllPlugin({
      path: path.join(__dirname, "../public/dll", "[name].manifest.json"),
      name: "_dll_[name]_[hash]"
    })
  ]
};

執(zhí)行npm run build:dll,CLI應(yīng)該會自動提示你安裝webpack-cli,運行完成后可以看到以下文件:

public/dll
├── react.dll.js
└── react.manifest.json
DLLReferencePlugin

打開config/webpack.config.js,在根對象plugins字段中寫入該插件:

{
  plugins: [
    // ...
    new webpack.DllReferencePlugin({
        manifest: require(path.join(
        __dirname,
        "../public/dll/react.manifest.json"
        ))
    }),
  ]
}

最后一個步驟,在index.html我們先手動引入dll依賴:

    ...
    
...

此時重新運行程序,等待項目正常運行,再檢查一下編譯信息:

Version: webpack 4.28.3
Time: 4883ms
Built at: 2019-02-21 11:19:11
                         Asset       Size        Chunks             Chunk Names
           asset-manifest.json  232 bytes                [emitted]
                    index.html   1.69 KiB                [emitted]
          static/js/0.chunk.js   1.82 MiB             0  [emitted]
           static/js/bundle.js   30.9 KiB  runtime~main  [emitted]  runtime~main
       static/js/main.chunk.js   52.1 KiB          main  [emitted]  main
static/media/logo.5d5d9eef.svg   2.61 KiB                [emitted]

很顯然的看到,在development模式下,構(gòu)建時間降低了2s,打包大小降低了2.4M,相信將DLL運用到項目工程中,你能收獲到更多的驚喜。

優(yōu)化

以上程序只是為了快速入手與demo搭建,需要優(yōu)化的地方還有很多,在此簡單的列舉幾點,供大家參考。

自動注入編譯文件到HTML

通過安裝html-webpack-include-assets-plugin插件,可以自動將相應(yīng)文件注入到index.html中,就可以避免手動進行更改了:

// config/webpack.config.js
const HtmlIncludeAssetsPlugin = require("html-webpack-include-assets-plugin");
// ...
{
  plugins: [
    new HtmlIncludeAssetsPlugin({
      assets: ["dll/react.dll.js"],
      append: false // 在其他資源前添加
    }),
  ]
}
DLL的緩存問題與自動加載

我們通常不會對html文件做緩存,每次發(fā)版本時采用增量發(fā)布,只要html的依賴文件名變了,則會重新去解析靜態(tài)資源列表。除此之外,還需要提供一個函數(shù),自動去加載文件夾內(nèi)的多入口dll文件,以下為核心代碼:

config/dllHelper.js:

// config/dllHelper.js
const webpack = require("webpack");
const path = require("path");
const fs = require("fs");
const dllConfig = require("./webpack.dll.config");

// 根據(jù)entry生成DllReferencePlugin列表
function genDllReferences() {
  return Object.keys(dllConfig.entry).map(
    name =>
      new webpack.DllReferencePlugin({
        manifest: require(path.join(
          __dirname,
          "../public/dll",
          `${name}.manifest.json`
        ))
      })
  );
}

// 生成dll文件的靜態(tài)資源路徑
function loadDllAssets() {
  return fs
    .readdirSync(path.resolve(__dirname, "../public/dll"))
    .filter(filename => filename.match(/.dll.js$/))
    .map(filename => `dll/${filename}`);
}

module.exports = {
  loadDllAssets,
  genDllReferences
};

config/webpack.dll.config.js:

// 
{
  ...
  output: {
    filename: "[name].[hash:8].dll.js"
  }
}

config/webpack.config.js:

const dllHelper = require("./dllHelper");
...
{
  plugins: [
    ...dllHelper.genDllReferences(),
    new HtmlIncludeAssetsPlugin({
      assets: dllHelper.loadDllAssets(), 
      append: false
    })
  ]
}
構(gòu)建前清空文件夾

若DLLPlugiun的entry發(fā)生變化,則dll內(nèi)的文件可能會越來越多,因此我們需要在構(gòu)建dll前清空文件夾,在這里推薦這兩個package:

npm-run-all,在scripts可串行或并行執(zhí)行script

rimraf,nodejs刪除文件利器

首先安裝相應(yīng)依賴:yarn add -D rimraf npm-run-all,然后修改package.json:

scripts: {
  "make:dll": "npm-run-all clear:dll build:dll",
  "build:dll": "webpack --config config/webpack.dll.config.js --mode production",
  "clear:dll": "rimraf public/dll",
}

之后在變動DLL時,一定要記得執(zhí)行:npm run make:dll。

其他

Demo倉庫地址:GitHub - vv13/react-dll-demo

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

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

相關(guān)文章

  • Vue-cli3 簡qian易yi教程

    摘要:原文地址對于沒有了解過的童鞋,建議先去看看官方的教程傳送門新版本的新特性插件使用的插件,可以很快的搭建一個項目的結(jié)構(gòu)。使用時直接引入即可。的界面讓管理項目變得更加簡單。如遷移過程中有任何疑問,可以留言一起探討。 原文地址 對于沒有了解過 vue-cli3 的童鞋,建議先去看看官方的教程: 傳送門 新版本的新特性 1. 插件 使用 cli 的插件,可以很快的搭建一個項目的結(jié)構(gòu)。如 ax...

    jemygraw 評論0 收藏0
  • webpack dll打包重復(fù)問題優(yōu)化

    摘要:關(guān)于的使用,我這里不做過多介紹,網(wǎng)上都有,一擼一大把,今天我要說的是在使用過程中出現(xiàn)的一個包依賴問題,這個問題導(dǎo)致打出來的包會包含重復(fù)的代碼。 關(guān)于webpack dll的使用,我這里不做過多介紹,網(wǎng)上都有,一擼一大把,今天我要說的是在使用dll plugin過程中出現(xiàn)的一個包依賴問題,這個問題導(dǎo)致打出來的包會包含重復(fù)的代碼。 優(yōu)化背景 最近在給公司項目優(yōu)化的時候,由于內(nèi)部CDN上傳文...

    NicolasHe 評論0 收藏0
  • webpack多頁應(yīng)用架構(gòu)系列(十一):預(yù)打包Dll,實現(xiàn)webpack音速編譯

    摘要:本文首發(fā)于的技術(shù)博客實用至上,非經(jīng)作者同意,請勿轉(zhuǎn)載。原文地址如果您對本系列文章感興趣,歡迎關(guān)注訂閱這里前言書承上文多頁應(yīng)用架構(gòu)系列十如何打造一個自定義的。終于,發(fā)現(xiàn)了這一大殺器,打包時間過長的問題得到完美解決。 本文首發(fā)于Array_Huang的技術(shù)博客——實用至上,非經(jīng)作者同意,請勿轉(zhuǎn)載。原文地址:https://segmentfault.com/a/119000000710437...

    sixleaves 評論0 收藏0
  • vue-cli配置webpack dll

    摘要:一緩存失效改變了的一點兒代碼,打包的就會改變導(dǎo)致每次發(fā)布,的緩存都會失效。為了解決上述問題,在網(wǎng)上查找資料后,找到使用這個方案。三對比結(jié)果優(yōu)化前筆記本上打包時間為,優(yōu)化后筆記本打包時間為,同時也增加了這些庫的緩存。 問題 在前端項目中,我們希望第三方庫(vendors)和自己寫的代碼可以分開打包,vue-cli也幫我們配好了webpack的CommonsChunkPlugin,但是在使...

    justCoding 評論0 收藏0
  • vue-cli配置預(yù)編譯

    摘要:轉(zhuǎn)載文章公司的平臺功能越堆越多,打包也越來越費勁,一次十幾分鐘,運維很不爽,搗鼓了一下預(yù)編譯,試了一下大概縮短了七八分鐘,目前感覺還行,現(xiàn)在把它記下來,給需要的童鞋當做參考,也給自己記錄一下。 (轉(zhuǎn)載文章)公司的平臺功能越堆越多,打包也越來越費勁,一次十幾分鐘,運維很不爽,so搗鼓了一下預(yù)編譯,試了一下大概縮短了七八分鐘,目前感覺還行,現(xiàn)在把它記下來,給需要的童鞋當做參考,也給自己記錄...

    KnewOne 評論0 收藏0

發(fā)表評論

0條評論

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