
https://juejin.cn/post/6844904193589772301
1 | 何为插件(Plugin)?专注处理 webpack 在编译过程中的某个特定的任务的功能模块,可以称为插件。 |
Plugin 是一个扩展器,它丰富了 webpack 本身,针对是 loader 结束后,webpack 打包的整个过程,它并不直接操作文件,而是基于事件机制工作,会监听 webpack 打包过程中的某些节点,执行广泛的任务。
Plugin 的特点
是一个独立的模块
模块对外暴露一个 js 函数
1 | 函数的原型 `(prototype)` 上定义了一个注入 |
compiler
对象的
apply
方法
函数中需要有通过
对象挂载的
webpack
事件钩子,钩子的回调中能拿到当前编译的
compilation
对象,如果是异步编译插件的话可以拿到回调
callback
完成自定义子编译流程并处理
complition
对象的内部数据
如果异步编译插件的话,数据处理完成后执行
回调。
下面介绍 18 个常用的 webpack 插件。
本文在gitthub做了收录:
https://github.com/Michael-lzg/my--article/blob/master/webpack/%E6%80%BB%E7%BB%9318%E4%B8%AAwebpack%E6%8F%92%E4%BB%B6.md
一、Webpack插件详解
1.1 HotModuleReplacementPlugin
模块热更新插件。Hot-Module-Replacement
的热更新是依赖于webpack-dev-server
,后者是在打包文件改变时更新打包文件或者 reload 刷新整个页面,HRM
是只更新修改的部分。
HotModuleReplacementPlugin
是
模块自带的,所以引入
后,在plugins
配置项中直接使用即可。
1 | const webpack = require('webpack')plugins: [ new webpack.HotModuleReplacementPlugin(), // 热更新插件] |
1.2 html-webpack-plugin
生成 html 文件。将 webpack 中entry
配置的相关入口chunk
和extract-text-webpack-plugin
抽取的 css 样式 插入到该插件提供的template
或者templateContent
配置项指定的内容基础上生成一个 html 文件,具体插入方式是将样式link
插入到head
元素中,script
插入到
或者body
中。
1 | const HtmlWebpackPlugin = require('html-webpack-plugin')plugins: [ new HtmlWebpackPlugin({ filename: 'index.html', template: path.join(__dirname, '/index.html'), minify: { // 压缩HTML文件 removeComments: true, // 移除HTML中的注释 collapseWhitespace: true, // 删除空白符与换行符 minifyCSS: true, // 压缩内联css }, inject: true, }),] |
1 |
|
如果需要配置多个HtmlWebpackPlugin
,那么filename
字段不可缺省,否则默认生成的都是index.html
。
但是有个问题,
和login.html
会发现,都同时引入了index.f7d21a.js
和login.f7d21a.js
,通常这不是我们想要的,我们希望
中只引入
,
只引入
。
提供了一个chunks
的参数,可以接受一个数组,配置此参数仅会将数组中指定的 js 引入到 html 文件中
1 | module.exports = { //... plugins: [ new HtmlWebpackPlugin({ template: './public/index.html', filename: 'index.html', //打包后的文件名 chunks: ['index'], }), new HtmlWebpackPlugin({ template: './public/login.html', filename: 'login.html', //打包后的文件名 chunks: ['login'], }), ],} |
1 |
|
1.4 extract-text-webpack-plugin
将 css 成生文件,而非内联 。该插件的主要是为了抽离 css 样式,防止将样式打包在 js 中引起页面样式加载错乱的现象
1 | const ExtractTextPlugin = require('extract-text-webpack-plugin')plugins: [ // 将css分离到/dist文件夹下的css文件夹中的index.css new ExtractTextPlugin('css/index.css'),] |
1 |
|
1.6 purifycss-webpack
有时候我们 css 写得多了或者重复了,这就造成了多余的代码,我们希望在生产环境进行去。
1 | const path = require('path')const PurifyCssWebpack = require('purifycss-webpack') // 引入PurifyCssWebpack插件const glob = require('glob') // 引入glob模块,用于扫描全部html文件中所引用的cssmodule.exports = merge(common, { plugins: [ new PurifyCssWebpack({ paths: glob.sync(path.join(__dirname, 'src/*.html')), }), ],}) |
1 |
|
1.8 UglifyJsPlugin
uglifyJsPlugin
是vue-cli
默认使用的压缩代码方式,用来对 js 文件进行压缩,从而减小 js 文件的大小,加速 load 速度。它使用的是单线程压缩代码,打包时间较慢,所以可以在开发环境将其关闭,生产环境部署时再把它打开。
1 | const UglifyJsPlugin = require('uglifyjs-webpack-plugin')plugins: [ new UglifyJsPlugin({ uglifyOptions: { compress: { warnings: false } }, sourceMap: true, //是否启用文件缓存 parallel: true //使用多进程并行运行来提高构建速度 }) |
1 |
|
1.10 terser-webpack-plugin
Webpack4.0 默认是使用terser-webpack-plugin
这个压缩插件,在此之前是使用uglifyjs-webpack-plugin
,两者的区别是后者对 ES6 的压缩不是很好,同时我们可以开启parallel
参数,使用多进程压缩,加快压缩。
1 | const TerserPlugin = require('terser-webpack-plugin') // 压缩js代码optimization: { minimizer: [ new TerserPlugin({ parallel: 4, // 开启几个进程来处理压缩,默认是 os.cpus().length - 1 cache: true, // 是否缓存 sourceMap: false, }), ]} |
1 |
|
当然,这个方法还需要后端配置支持。
1.12 DefinePlugin
我们可以通过DefinePlugin
可以定义一些全局的变量,我们可以在模块当中直接使用这些变量,无需作任何声明,
是
自带的插件。
1 | plugins: [ new webpack.DefinePlugin({ DESCRIPTION: 'This Is The Test Text.', }),]// 直接引用console.log(DESCRIPTION) |
1 |
|
1.14 DLLPlugin
1 | 这是在一个额外的独立的 webpack 设置中创建一个只有 dll 的 `bundle(dll-only-bundle)` 。这个插件会生成一个名为 |
manifest.json
的文件,这个文件是用来让DLLReferencePlugin
映射到相关的依赖上去的。
使用步骤如下
1、在 build 下创建webpack.dll.config.js
1 | const path = require('path')const webpack = require('webpack')module.exports = { entry: { vendor: [ 'vue-router', 'vuex', 'vue/dist/vue.common.js', 'vue/dist/vue.js', 'vue-loader/lib/component-normalizer.js', 'vue', 'axios', 'echarts', ], }, output: { path: path.resolve('./dist'), filename: '[name].dll.js', library: '[name]_library', }, plugins: [ new webpack.DllPlugin({ path: path.resolve('./dist', '[name]-manifest.json'), name: '[name]_library', }), // 建议加上代码压缩插件,否则dll包会比较大。 new webpack.optimize.UglifyJsPlugin({ compress: { warnings: false, }, }), ],} |
1 |
|
3、package.json
1 | 文件中添加快捷命令 `(build:dll)` ```java |
1 |
|
1 |
|
3、在生产环境
文件进行配置
1 | const HappyPack = require('happypack')// 构造出共享进程池,在进程池中包含5个子进程const HappyPackThreadPool = HappyPack.ThreadPool({ size: 5 })plugins: [ new HappyPack({ // 用唯一的标识符id,来代表当前的HappyPack是用来处理一特的文件 id: 'babel', // 如何处理.js文件,用法和Loader配置中一样 loaders: ['babel-loader?cacheDirectory'], threadPool: HappyPackThreadPool, }), new HappyPack({ id: 'vue', // 用唯一的标识符id,来代表当前的HappyPack是用来处理一类特定的文件 loaders: [ { loader: 'vue-loader', options: vueLoaderConfig, }, ], threadPool: HappyPackThreadPool, }),] |
1 |
|
1.17 IgnorePlugin
这是 webpack 内置插件,它的作用是:忽略第三方包指定目录,让这些指定目录不要被打包去
比如我们要使用moment
这个第三方依赖库,该库主要是对时间进行格式化,并且支持多个国家语言。虽然我设置了语言为中文,但是在打包的时候,是会将所有语言都打包进去的。这样就导致包很大,打包速度又慢。对此,我们可以用IgnorePlugin
使得指定目录被忽略,从而使得打包变快,文件变小。
1 | const Webpack = require('webpack')plugins: [ //moment这个库中,如果引用了./locale/目录的内容,就忽略掉,不会打包进去 new Webpack.IgnorePlugin(/\.\/locale/, /moment/),] |
1 |
|

本文标题: 总结18个 webpack 插件,总会有你想要的!
发布时间: 2022年03月05日 00:00
最后更新: 2025年12月30日 08:54
原始链接: https://haoxiang.eu.org/5c706c0c/
版权声明: 本文著作权归作者所有,均采用CC BY-NC-SA 4.0许可协议,转载请注明出处!

