npm run 做了什么(详细步骤)?

1.前言

最近敲了一个后端nodejs+MongoDB+express,前端vue3+vite的项目。

然后我发现前后端启动的命令不同,这引发了我的思考

前端:

package.json中scripts部分

json 复制代码
  "scripts": {
    "dev": "vite",
    "build": "run-p type-check "build-only {@}" --",
  },

启动命令:

shell 复制代码
npm run dev

后端

package.json中scripts部分

json 复制代码
  "scripts": {
    "start": "nodemon ./bin/www"
  },

启动命令

shell 复制代码
 npm start

虽然前后端项目的命令都是写在package.json的scripts中,但是一个需要加run,一个不需要加run这是为什么呢?

2.npm run做了什么?

要弄清楚为什么一个执行脚本命令npm需要加上run,一个执行脚本命令npm可以不加,我们首先先弄清楚npm run 做了什么

npm文档: npm-run-script 详解

2.1终端输入命令

首先我们在终端输入比如npm run <command> [-- <args>]的命令

arduino 复制代码
npm run dev 

2.2 到package.json的scripts中寻找命令

在终端输入了如下面命令后

arduino 复制代码
npm run <command>

npm得到command命令,然后到package.json的"scripts"中寻找相同的命令,然后运行命令,

如果没有找到则会提示没有该命令,并告诉我们输入npm run可以列出所有scripts列表

输入npm run可以显示所有可用scripts:

2.3执行命令

例如我执行了启动命令:

arduino 复制代码
npm run dev

package.json中scripts部分如下:

json 复制代码
  "scripts": {
    "dev": "vite"
  }

npm在找到dev命令之后,需要执行vite命令,

  • npm首先会到当前项目的node_modules.bin目录下找vite命令
  • 找不到就到系统环境变量中找vite

找到后执行vite命令启动项目

3.为什么有的npm scripts命令不用run

npm文档: npm-run-script 详解

查看npm 文档可知test、start、restart 和 stop四个scripts命令是可以直接调用的命令,(使用run也可以),原因是他们是生命周期(测试,启动,重启)和直接运行的脚本.

原文如下

run[-script] is used by the test, start, restart, and stop commands, but can be called directly, as well. When the scripts in the package are printed out, they're separated into lifecycle (test, start, restart) and directly-run scripts.

也就是说其实npm startnpm run start效果是一样的,如下都能启动node项目:

当然test、restart 和 stop也是这样,

当然前提是先要在package.json中scripts部分中定义command.例子如下

json 复制代码
  "scripts": {
    "start": "nodemon ./bin/www",
    "test": "echo "Error: no test specified" && exit 1",
    "restart": "pm2 restart server",
    "stop": "pm2 stop server"
  },

4.总结

npm run 执行步骤如下:

1.终端输入命令npm run <command>

2.npm 到package.json"scripts"中寻找有无对应的命令,找到对应命令继续下一步,未找到提示未找到

3.找到对应命令后,执行具体命令,先到当前项目目录下node_modules.bin找对应命令,找不到到系统环境变量去找

4.如果都没有找到该命令,提示该命令不是内部或外部命令,也不是可运行的程序或批处理文件。

四个脚本命令使用npm run <command>npm <command>直接执行相同

分别是test,start,restart,stop

不同的系统运行命令执行的shell不同,因此往往在bin下面同一个命令有三个shell

以vite为例,分别为

  • vite 在 Unix/Linux 系统执行 (mac/linux)
  • vite.cmd 在Windows命令提示符中运行(cmd)
  • vite.ps1 在 PowerShell 中运行
相关推荐
小李子呢02111 分钟前
为什么会有react和vue这些框架的出现
前端·vue.js·react.js
军训猫猫头1 分钟前
7.带输入参数的线程启动 C# + WPF 完整示例
开发语言·前端·c#·.net·wpf
CodeSheep2 分钟前
同事偷偷给我介绍私活,说1万报酬全给我,结果甲方私下告诉我说,同事在当中白拿了2万,我觉得被耍了,媳妇却让我要知足,说我一点不亏
前端·后端·程序员
鱼人3 分钟前
iOS 与 Android 兼容性常见坑点排查指南
后端
七夜zippoe3 分钟前
DolphinDB脚本语言:从入门到精通
后端·struts·脚本·语言·dolphindb
Betelgeuse763 分钟前
告别传统 ModelForm:用 React 与 DRF 打造现代化项目管理表单
前端·react.js·django·前端框架
IT_陈寒4 分钟前
SpringBoot这个"自动配置"差点让我加班到凌晨
前端·人工智能·后端
恋恋风尘hhh7 分钟前
文字点选验证码前端安全研究:以网易易盾(dun.163)为例
前端·安全
鹏程十八少8 分钟前
1.2026金三银四 Android Glide 23连问终极拆解:生命周期、三级缓存、Bitmap复用,大厂面试官到底想听什么?
android·前端·面试
hhhhhh_we8 分钟前
预颜美历:AI驱动的私人面部美学与皮肤全周期管理工具
前端·图像处理·人工智能·python·aigc