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文档
相关推荐
好好学习啊天天向上12 小时前
CFD,GPU加速效果,FUN3D GPU移植加速效果2
javascript·opencv·webpack
问道飞鱼2 天前
【前端知识】前端项目不同构建模式的差异
前端·webpack·构建·开发模式·生产模式
Rabi'2 天前
编译ATK源码
前端·webpack·node.js
紫小米2 天前
webpack详解和实操
前端·webpack·node.js
karshey3 天前
【前端】svelte支持scss,包管理器是webpack
前端·webpack·scss
转转技术团队4 天前
基于微前端 qiankun 多实例保活的工程实践
前端·javascript·前端工程化
Roc.Chang5 天前
终极指南:解决 Vue 项目中 “regenerator-runtime/runtime“ 缺失报错
前端·javascript·vue.js·webpack·前端工程
Maxkim5 天前
一文读懂 Chrome CRX📦:你需要了解的核心知识点
前端·前端工程化