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文档
相关推荐
莫循瑾木35 分钟前
Vue3 Composition API 完全指南
前端·vue.js·前端工程化
qp14 小时前
21.OpenCV获取图像轮廓信息
javascript·opencv·webpack
随笔记1 天前
vite构建工具和webpack构建工具有什么共同点和不同处
vue.js·react.js·webpack
疾风铸境2 天前
Qt5.14.2+mingw64编译OpenCV3.4.14一次成功记录
前端·webpack·node.js
try again!2 天前
rollup.js 和 webpack
开发语言·javascript·webpack
依旧7052 天前
webpack打包流程
webpack
ak啊2 天前
Webpack打包过程中的核心机制-Chunk 的生成与优化
前端·webpack·源码
挖稀泥的工人2 天前
面试看这一篇webpack
前端·webpack
雾散尽时2 天前
Webpack在项目中的配置与工作原理解析
webpack
程序员黄同学3 天前
解释 Webpack 中的模块打包机制,如何配置 Webpack 进行项目构建?
前端·webpack·node.js