Webpack项目如何改了配置文件自动重启项目

前期场景

基于Webpack的项目,项目的配置文件、package.json、环境变量文件发生了变更都需要手动重启项目,才可以在浏览器中看到效果。由于这些都是静态的配置文件,如果需要让他们的变更能够触发项目自动重启,就需要一个工具去监听他们的变化,这个时候nodemon隆重登场了

nodemon^1^

nodemon 是一个工具,可在检测到目录中的文件更改时自动重新启动节点应用程序,从而帮助开发基于 Node.js 的应用程序。

nodemon不需要对您的代码或开发方法进行任何额外的更改。要使用nodemon,请在执行脚本时nodemon 替换命令行上的单词node

全局安装

powershell 复制代码
npm i -g nodemon

局部安装

powershell 复制代码
npm i -D nodemon

使用配置

启动命令配置

powershell 复制代码
{
	script:{
		"serve-w":"nodemon --watch vue.config.js exec \"vue-cli-service serve\""
	}
}

在package.json中配置

package.json文件中添加nodemonConfig节点

javascript 复制代码
{
  "name": "nodemon",
  "homepage": "http://nodemon.io",
  "...": "... other standard package.json values",
  "nodemonConfig": {
  	"watch":["vue.config.js",".env"],
  	"exec":"vue-cli-service serve"
  }
}

再在package.json添加启动命令

javascript 复制代码
{
 	"script":{
 		"serve-w":"nodemon"
	}
}

项目根目录添加nodemon.json文件

javasript 复制代码
{
  	"watch":["vue.config.js",".env"],
  	"exec":"vue-cli-service serve"
}

再在package.json添加启动命令

javascript 复制代码
{
 	"script":{
 		"serve-w":"nodemon"
	}
}

常用配置参数说明

参数名 参数描述 数据类型
watch 需要监听的文件或文件夹 Array
exec 监听后需要启动的命令 String
ignore 需要忽略监听的文件或文件夹 Array
delay 延迟重启的时间,默认单位秒可传入精确单位如:2500ms String,Number
events 当nodemon状态改变时触发事件,定义通知的文字 String

结尾拓展

经过这样子配置,一编辑被监听的文件,就会触发项目自动的重启,而项目启动的时长是与项目的大小成正相关的,如果项目很大,项目重启时间过长,这样也会减轻开发体验;这时就可以通过splitChunk来减轻编译形成的包的大小,模块分包(静态模块预编译)来预先将部分node_modules包打包来降低编译的内容的大小,再通过开启Webpack的持久缓存和多进程编译来提升二次编译的速度,从而减少项目重启的时长

文章参考

Footnotes

  1. nodemon文档
相关推荐
光影少年1 小时前
webpack打包优化
webpack·掘金·金石计划·前端工程化
奔跑的蜗牛ing19 小时前
Vue3 + Element Plus 输入框省略号插件:零侵入式全局解决方案
vue.js·typescript·前端工程化
ygria19 小时前
样式工程化:如何实现Design System
前端·前端框架·前端工程化
白水清风2 天前
CI/CD学习记录(基于GitLab)
前端·自动化运维·前端工程化
百思可瑞教育2 天前
Vue.config.js中的Webpack配置、优化及多页面应用开发
前端·javascript·vue.js·webpack·uni-app·北京百思教育
歪歪1002 天前
webpack 配置文件中 mode 有哪些模式?
开发语言·前端·javascript·webpack·前端框架·node.js
歪歪1002 天前
如何配置Webpack以实现按需加载模块?
开发语言·前端·webpack·node.js
谢尔登3 天前
【Webpack】模块联邦
前端·webpack·node.js
Yvonne爱编码5 天前
构建高效协作的桥梁:前后端衔接实践与接口文档规范详解
前端·git·ajax·webpack·node.js
会有钱的-_-5 天前
基于webpack的场景解决
前端·vue.js·webpack·安全性测试