每次写完代码都需要手动输入指令才能编译代码,太麻烦了,我们希望一切自动化
1. 安装并配置webpack开发服务
- 安装所需依赖
npm i webpack-dev-server -D
- 开启服务器配置
文件名:webpack.config.js
module.exports = {
// ...
// 开发服务器
devServer: {
host: "localhost", // 启动服务器域名
port: "3000", // 启动服务器端口号
open: true, // 是否自动打开浏览器
},
mode: "development",
};
- 运行服务器
npx webpack serve
并且当你使用开发服务器时,所有代码都会在内存中编译打包,并不会输出到 dist 目录下。
开发时我们只关心代码能运行,有效果即可,至于代码被编译成什么样子,我们并不需要知道。
2. 关于修改输出资源的名称和路径问题
如果你想你的js打包输出在一个指定的目录可以在output对象里面进行配置:
文件名:webpack.config.js
const path = require("path");
module.exports = {
entry: "./src/main.js",
output: {
path: path.resolve(__dirname, "dist"),
filename: "static/js/main.js", // 将 js 文件输出到 static/js 目录中
},
// ...
}
如果你想你的图片资源也输出在一个指定目录可以这样配置:
文件名:webpack.config.js
module.exports = {
entry: "./src/main.js",
output: {
path: path.resolve(__dirname, "dist"),
filename: "static/js/main.js", // 将 js 文件输出到 static/js 目录中
},
module: {
rules: [
// ...
{
test: /\.(png|jpe?g|gif|webp)$/,
type: "asset",
parser: {
dataUrlCondition: {
maxSize: 10 * 1024, // 小于10kb的图片会被base64处理
},
},
generator: {
// 将图片文件输出到 static/imgs 目录中
// 将图片文件命名 [hash:8][ext][query]
// [hash:8]: hash值取8位
// [ext]: 使用之前的文件扩展名
// [query]: 添加之前的query参数
filename: "static/imgs/[hash:8][ext][query]",
},
},
],
},
plugins: [],
mode: "development",
};
运行webpack
npx webpack
你可以看到对应文件的输出目录。
3. 关于自动清空上一次的打包资源
- 清空所有output生成的目录
module.exports = {
//...
output: {
clean: true, // 在生成文件之前清空 output 目录
},
};
- 打印而不是删除应该移除的静态资源
module.exports = {
//...
output: {
clean: {
dry: true, // 打印而不是删除应该移除的静态资源
},
},
};
- 保留 指定目录下的静态资源
module.exports = {
//...
output: {
clean: {
keep: /ignored\/dir\//, // 保留 'ignored/dir' 下的静态资源
},
},
};
// 或者
module.exports = {
//...
output: {
clean: {
keep(asset) {
return asset.includes('ignored/dir');
},
},
},
};
- 对应你需要的情况运行webpack观察结果
npx webpack
观察dist目录的变化情况。