webpack --mode development/production
在webpack打包时默认的位置是当前目录下的./src/index.js
通过命令webpack --mode ./文件夹/文件 -o ./文件夹/文件夹 development
来自定义打包内容和输出,打包输出为main.js
创建webpack.config.js
作为配置文件。
要在配置中引入插件来提供打包功能,sass或less用的是模块
下载插件:npm i html-webpack-plugin -d
使用插件:在plush中new
引入的插件,如果不写实例化时的设置,会创建空的html引入打包的js文件;实例时的参数见下面代码的注释。
plush数组中传入多个插件的实例来打包,通过chunk
放入打包的js名来引入。
entry: {
vue: "./src/myVue/vue.js",
test1: "./src/js/test.js",
test2: "./src/js/index.js",
test1Style: "./src/js/test1Style.js", // 用js来设置引入的css
},
output: {
filename: "[name].js", // name对应entry里的key
path: path.resolve(__dirname, "build"),
},
plugins: [
//? test1
new HtmlWebpackPlugin({
template: "./src/test1.html",
filename: "test1.html",
chunks: ["test1", "test1Style"],
minify: {
//collapseWhitespace: true, //删除空格
removeComments: true, // 删除注释
},
}),
//? test2
new HtmlWebpackPlugin({
template: "./src/test2.html",
filename: "test2.html",
chunks: ["vue", "test1"],
minify: {
//collapseWhitespace: true, //删除空格
removeComments: true, // 删除注释
},
}),
]
下载插件:npm i css-loader style-loader -d
使用插件:在module.rules
中放入设置
被打包的css通过requre
引入一个js文件,然后配置js文件进需要使用的html
module: {
rules: [
//! 将样式写入head里
{
test: /\.css$/, //? 匹配css文件
use: ["style-loader", "css-loader"],
// loader:"", //! 如果只引入一个
},
{
test: /\.less$/,
use: ["style-loader", "css-loader", "less-loader"],
},
],
},
// test1Style.js
require("../css/style.css");
require("../css/lessStyle.less");
下载插件:npm i less less-loader -d
npm i node-sass sass-loader -d
使用插件:与打包css相似
下载插件:npm i mini-css-extract-plugin -d
使用插件:与使用打包html的插件相似 需要在module中将原来的style-loader
改为插件的loader
静态方法。
module:{
rules:[
//! 将样式单独引入
{
test: /\.css$/, //? 匹配css文件
use: [MiniCssExtractPlugin.loader, "css-loader", "postcss-loader"],
},
{
test: /\.less$/,
use: [MiniCssExtractPlugin.loader, "css-loader", "less-loader", "postcss-loader"],
},
]
}
下载插件:npm i postcss-loader postcss-preset-env -d
使用插件:在样式模块最后新加入postcss-loader
;新建postcss.config.js
文件配置插件,然后在package.json
中配置。
// postcss.config.js
module.exports = {
plugins: [require("postcss-preset-env")()],
};
// package.json
{"browserslist": [
"> 0.2%",
"not dead"
]}
下载插件:npm i optimize-css-assets-webpack-plugin -d
使用插件:在plugin中实例化插件。
plugins:[new OptimizeCssAssetsWebpackPlugin()],
插件下载:npm i url-loader file-loader -d
在html中引入图片需要npm i html-withimg-loader -d
插件下载:npm i webpack-dev-server -g -d
通过webpack serve
来运行
在webpack.config.js
中能通过devServer
进行配置
在webpack中自带了删除无用js代码的工具,只需要在运行webpack时处于pro模式,且js代码是用ES6导入的,就可以进行删减。
插件下载:npm i purgecss-webpack-plugin -d
插件使用:在plugins
中添加插件实例
plugins:[new PurgecssPlugin({
paths:golb.sync(`${Path.src}/**/*`,{ nodir:true })
})]
原文:https://www.cnblogs.com/shaddollxz/p/15077008.html