前言
在用 Webpack 打包的时候,对于一些不经常更新的第三方库,比如 react,lodash,我们希望能和自己的代码分离开,Webpack 社区有两种方案
- CommonsChunkPlugin
- DLLPlugin
对于 CommonsChunkPlugin
,webpack 每次打包实际还是需要去处理这些第三方库,只是打包完之后,能把第三方库和我们自己的代码分开。而DLLPlugin
则是能把第三方代码完全分离开,即每次只打包项目自身的代码。
用法
要使用 DLLPlugin,需要额外新建一个配置文件。所以对于用这种方式打包的项目,一般会有下面两个配置文件
- webpack.config.js
- webpack.dll.config.js
先来看下 webpack.dll.config.js
const webpack = require('webpack') const library = '[name]_lib' const path = require('path') module.exports = { entry: { vendors: ['react', 'lodash'] }, output: { filename: '[name].dll.js', path: 'dist/', library }, plugins: [ new webpack.DllPlugin({ path: path.join(__dirname, 'dist/[name]-manifest.json'), // This must match the output.library option above name: library }), ], }
再改下 webpack.config.js
文件
const webpack = require('webpack') module.exports = { entry: { app: './src/index' }, output: { filename: 'app.bundle.js', path: 'dist/', }, plugins: [ new webpack.DllReferencePlugin({ context: __dirname, manifest: require('./dist/vendors-manifest.json') }) ] }
manifest: require('./dist/vendors-manifest.json')
这里的路径要和 webpack.dll.config.js
里面的对应。
然后运行
$ webpack --config webpack.dll.config.js $ webpack --config webpack.config.js
然后你的 html 文件像下面这样引用
<script src="/UploadFiles/2021-04-02/vendors.dll.js">DLL Link Plugin
上面的用法也存在一些不方便的地方,比如在
webpack.config.js
中要明确指出对应的manifest.json
文件。还有当 DLL 需要更新的时候,比如react
升级了,或者加入新的第三方库,都需要手动像下面这样编译一次。$ webpack --config webpack.dll.config.js因为上面这些问题,所以基于官方的
DllReferencePlugin
,我写了一个打包的插件,Dll Link Plugin。使用这个插件,只需要对 webpack.config.js 作下小小的改动
const webpack = require('webpack') const DllLinkPlugin = require('dll-link-webpack-plugin') module.exports = { // ... plugins: [ new DllLinkPlugin({ config: require('webpack.dll.config.js') }) ] }直接替换掉
DllReferencePlugin
,然后传入对应的 DLL 配置文件就可以了。每次打包的时候,只需要运行$ webpack --config webpack.config.js上面的命令便会自动生成对应的 vendors 文件,需要更新的时候,也会自动更新。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 群星.1991-宝丽金精装国语专辑2CD【宝丽金】【WAV+CUE】
- 群星 -《2024好听新歌(01)》十倍音质 U盘音乐 [WAV分轨][1G]
- 伍佰2004《爱你伍佰年》世纪典藏原音精选台首版 3cd[低速原抓WAV+CUE][2G]
- 张艾嘉1997《滚石24K》24K金碟珍藏版系列[低速原抓WAV+CUE][1.1G]
- 宝可梦大集结开服有哪些免费时装获取 大集结免费时装获取大全
- 宝可梦大集结国服新手宝可梦怎么选 新手公测宝可梦推荐
- 宝可梦大集结国服公测福利获取方法大全 大集结开服福利有哪些
- AminaFigarova-SuiteForAfrica(2024)[24-96]FLAC
- 黑鸭子VS绿色森林2007-男女情歌对唱[首版][WAV+CUE]
- 群星《半个月亮爬上来》[DTS-WAV]
- 日本大雷少女COS赏
- 《怪猎荒野》PS5Pro性能表现一般 外媒:会有专门优化
- 《碟中谍8》首支预告公布!阿汤哥手扒飞机惊心动魄
- 孙露《忘不了》1:1黄金母盘直刻珍藏版[低速原抓WAV分轨][1G]
- 试音宝典《试机二十六号》K2HD母盘直刻[低速原抓WAV+CUE][1.1G]