经过webpack命令打包文件: 模块化转换,代码压缩合并
const path = require('path');
// 下包并导入插件 npm i html-webpack-plugin -D
const HtmlWebpackPlugin = require('html-webpack-plugin');
// npm i clean-webpack-plugin -D 清除目录中的内容
const { CleanWebpackPlugin } = require('clean-webpack-plugin');
module.exports = {
// 配置打包选项 development开发环境
mode: 'development', // production 生产环境
// 指定入口文件:要打包的文件
entry: './src/js/index.js',
// 指定输出文件:打包以后的文件
output: {
path: path.resolve(__dirname, 'dist'),
filename: 'main.min.js'
},
// 配置资源的加载器 loader
module: {
rules: [
// 配置js的加载器(把ES6转化为ES3/5代码)
{
test: /\.jsx?$/,
loader: 'babel-loader',
//打包除这个文件以外的文件
exclude: path.join(__dirname, './node_modules'),
//打包包括的文件
include: path.join(__dirname, './src')
},
// 配置css的加载器
{
// 匹配.css结尾的文件
test: /\.css$/,
// 配置css文件的加载器,处理顺序:从右向左
use: ['style-loader', 'css-loader']
},
// 配置less的加载器
{
test: /\.less$/,
use: ['style-loader', 'css-loader', 'less-loader']
}
]
},
// 配置插件
plugins: [
new CleanWebpackPlugin(),
// 动态生成html
new HtmlWebpackPlugin({
title: '测试标题',
template: 'index.html'
})
],
// 配置实时预览环境
devServer: {
contentBase: path.join(__dirname, 'dist'),
port: 5000
}
}
复制代码
"scripts": {
"dev": "npx webpack-dev-server --open"
}
复制代码