初衷: 分享一下工做中实用的几个Plugin
,但愿对你们有些帮助,不喜勿喷。javascript
用途: 将一个页面模板打包到dist目录下,默认都是自动引入js or csscss
安装html
cnpm i html-webpack-plugin@3.2.0 -D
复制代码
配置前端
index.htmlvue
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>首页</title>
</head>
<body>
<div id="app"></div>
</body>
</html>
复制代码
webpack.config.jsjava
const HtmlWebpackPlugin = require('html-webpack-plugin');
module.exports = {
plugins: [
new HtmlWebpackPlugin({
template: './index.html', // 以我们本地的index.html文件为基础模板
filename: "index.html", // 输出到dist目录下的文件名称
}),
]
}
复制代码
HtmlWebpackPlugin
接收一个对象,里面自行进行配置,详细参见这里node
用途: 用于每次打包dist目录删除webpack
安装git
cnpm i clean-webpack-plugin -D
复制代码
配置github
webpack.config.js
const { CleanWebpackPlugin } = require('clean-webpack-plugin');
module.exports = {
plugins: [
new CleanWebpackPlugin()
]
}
复制代码
用途: 将css
样式从js
文件中提取出来最终合成一个css
文件,该插件只支持webpack4
以前的版本,若是你当前是webpack4
及以上版本那么就会报错。
安装
cnpm i extract-text-webpack-plugin -D
复制代码
配置
webpack.config.js
const extractTextPlugin = require('extract-text-webpack-plugin');
module.exports = {
module: {
rules: [
{
test: /\.css$/,
use: extractTextPlugin.extract({
fallback: "style-loader",
use: "css-loader"
})
}
]
},
plugins: [
new extractTextPlugin({
filename: "[name].css",
allChunks: true
})
]
}
复制代码
上面配置中,extractTextPlugin.extract
里面参数fallback
是当提取不成功时,就执行style-loader
。use
里面是提取时使用css-loader
进行转换,plugins
里面的配置filename
是最后合并完的.css
文件名称,当allChunks
为false
时,只会提取初始化时的css
文件,为true
时会提取异步的css
文件。
用途: 该插件与上面的exract-text-webpack-plugin
的同样,都是将css样式提取出来, 惟一就是用法不一样,本插件的webpack4
版本以后推荐使用
安装
cnpm i mini-css-extract-plugin -D
复制代码
配置
webpack.config.js
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
module.exports = {
module: {
rules: [
{
test: /\.css$/,
use: [
MiniCssExtractPlugin.loader,
"css-loader"
]
}
]
},
plugins: [
new MiniCssExtractPlugin({
filename: "css/[name].css",
chunkFilename: "css/[name].css"
})
]
}
复制代码
上面配置中,能够看到用法与exract-text-webpack-plugin
不一样,来看一下它们的区别。
loader
配置没有fallback
plugin
中设置filename
同步加载资源名称,还要指定异步加载css
资源chunkFilename
publicPath
用来设置异步加载css
的路径exract-text-webpack-plugin
只会提取一个css文件,mini-css-extract-plugin
会根据异步文件提取出来。用途: 用于将页面里的公共代码提取出来,从而进行优化加载速度,该CommonsChunkPlugin
只支持Webpack4
以前。
安装
该插件是Webpack内置的,不须要安装。
复制代码
配置
main.js
import Vue from "vue"
复制代码
webpack.config.js
module.exports = {
entry: {
main: "./main.js",
vendor: ["Vue"]
},
plugins: [
new Webpack.optimize.CommonsChunkPlugin({
name: "vendor",
filename: "[name].js"
}),
new Webpack.optimize.CommonsChunkPlugin({
name: "common",
chunks: ["vendor"],
filename: "[name].js"
})
]
}
复制代码
上面配置中,咱们把main.js
及它里面的依赖文件把Vue.js
提取出来进行优化,避免每次打包或者每次访问其它页面都加载一个该js
文件, 咱们先是把Vue
基础环境提取出来,由于基础环境它几乎不会改变,从而进行提取优化是必须的。再把Webpack
运行时的代码也提取出来, 这样vendor
就再次打包也不会变化,能够走浏览器缓存
用途: 该功能与上面的webpack.optimize.CommonsChunkPlugin
同样,只不过optimization.SplitChunks
是webpack4
以后推荐使用的
安装
内置的,不须要安装。
复制代码
配置
main.js
import Vue from "vue"
console.log(Vue)
import("./news")
复制代码
news.js
import Vue from "vue"
console.log(Vue)
复制代码
webpack.config.js
module.exports = {
mode: "development",
entry: {
main: "./main.js"
},
output: {
filename: "[name].js",
path: __dirname + "/dist"
},
optimization: {
splitChunks: {
chunks: "all"
}
},
}
复制代码
上面配置中,splitChunks
的chunks
为all
是对全部的chunk
都生效,默认只对async
异步有效。
splitChunks
默认状况下也有自动提取,默认要求以下:
node_module
目录用途: 用于注入全局变量,通常用在环境变量上。
安装
无需安装,webpack内置
复制代码
配置
webpack.config.js
const Webpack = require("webpack")
module.exports = {
plugins: [
new Webpack.DefinePlugin({
STR: JSON.stringify("蛙人"),
"process.env": JSON.stringify("dev"),
name: "蛙人"
})
]
}
复制代码
上面配置中,DefinePlugin
接收一个对象,里面的key
值对应一个value
值,这个value
值是一个代码片断,能够看上面name
那个,会报错 蛙人 is not defined
,这里须要注意,value
值必须是一个变量或代码片断。
用途: 用于定义全局变量,如100个页面都引入vue
,每一个页面都引入只会增长工做量,直接在webpackProvide
挂载一个变量就行,不用再去一一引入。
安装
无需安装,webpack内置
复制代码
配置
webpack.config.js
const Webpack = require("webpack")
module.exports = {
plugins: [
new Webpack.ProvidePlugin({
"Vue": ["vue", "default"]
})
]
}
复制代码
上面配置中,ProvidePlugin
接收一个对象,key
值是使用的变量,value
值第一个参数是Vue
模块,第二个参数默认取Es Module.default
的属性。import
默认引入进来是一个 Es Module
的对象,里面有default
这个属性就是实体对象
用途: 开启热模块更新
安装
无需安装,webpack内置
复制代码
配置
webpack.config.js
const Webpack = require("webpack")
module.exports = {
plugins: [
new Webpack.HotModuleReplacementPlugin()
]
}
复制代码
用途: 用于过滤打包文件,减小打包体积大小。
安装
无需安装,webpack内置
复制代码
配置
webpack.config.js
const Webpack = require("webpack")
module.exports = {
plugins: [
new Webpack.IgnorePlugin(/.\/lib/, /element-ui/)
]
}
复制代码
用途: 用于压缩js
文件,针对webpack4
版本以上。
安装
cnpm install uglifyjs-webpack-plugin -D
复制代码
配置
webpack.config.js
const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
module.exports = {
optimization: {
minimizer: [
new UglifyJsPlugin({
test: /\.js(\?.*)?$/i,
exclude: /node_modules/
})
]
}
}
复制代码
用途: 用于将文件拷贝到某个目录下
安装
cnpm i copy-webpack-plugin@6.4.1 -D
复制代码
配置
webpack.config.js
const CopyWebpackPlugin=require('copy-webpack-plugin');
module.exports = {
plugins: [
new CopyWebpackPlugin({
patterns: [
{
from: "./main.js",
to: __dirname + "/dist/js",
toType: "dir"
}
]
})
]
}
复制代码
上面配置中,将main.js
拷贝到dist
目录下的js
里,toType
默认是file
,也能够设置为dir
,由于我这dist
目录下没有js
目录。
用途: 用于压缩css样式
安装
cnpm i optimize-css-assets-webpack-plugin -D
复制代码
配置
webpack.config.js
const OptimizeCssAssetsWebpackPlugin = require("optimize-css-assets-webpack-plugin")
module.exports = {
plugins: [
new OptimizeCssAssetsWebpackPlugin(),
]
}
复制代码
用途: 用于压缩图片
安装
cnpm i imagemin-webpack-plugin -D
复制代码
配置
webpack.config.js
const ImageminPlugin = require('imagemin-webpack-plugin').default
module.exports = {
plugins: [
new ImageminPlugin({
test: /\.(jpe?g|png|gif|svg)$/i
})
]
}
复制代码
用途: 美化控制台,良好的提示错误,。咱们不想本身的终端启动乱糟糟的,好比这样
安装
cnpm i friendly-errors-webpack-plugin -D
复制代码
配置
webpack.config.js
const FriendlyErrorsWebpackPlugin = require('friendly-errors-webpack-plugin');
const devServer = {
publicPath: "/",
port: 9527,
host: "localhost",
open: true,
hotOnly: true,
stats: 'errors-only'
}
module.exports = {
plugins: [
new FriendlyErrorsWebpackPlugin({
compilationSuccessInfo: {
notes: ['蛙人你好,系统正运行在http://localhost:' + devServer.port]
},
clearConsole: true,
})
],
devServer
}
复制代码
运行完上面代码。看以下结果
谢谢你读完本篇文章,但愿对你能有所帮助,若有问题欢迎各位指正。
我是蛙人(✿◡‿◡),若是以为写得能够的话,请点个赞吧❤。
感兴趣的小伙伴能够加入 [ 前端娱乐圈交流群 ] 欢迎你们一块儿来交流讨论
写做不易,「点赞」+「在看」+「转发」 谢谢支持❤
《聊聊什么是CommonJs和Es Module及它们的区别》