webpack5开发服务器与自动化
Posted 天界程序员
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了webpack5开发服务器与自动化相关的知识,希望对你有一定的参考价值。
每次写完代码都需要手动输入指令才能编译代码,太麻烦了,我们希望一切自动化
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目录的变化情况。
以上是关于webpack5开发服务器与自动化的主要内容,如果未能解决你的问题,请参考以下文章