欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

npm run dev 与 npm run serve

程序员文章站 2022-03-03 08:42:11
...

1、npm run dev 还是 npm run serve

最近运行一些前端项目的时候,发现不同的项目有使用npm run dev,有的使用npm run serve,所以就很好奇,这是怎么回事,输入命令错误后,会报如下错,所以就想探究一下原因。下面是一些相关报错如下:

npm run dev
npm ERR! missing script: dev

npm ERR! A complete log of this run can be found in:
npm ERR!     E:\nodejs\node_cache\_logs\2018-12-12T15_06_08_674Z-debug.log

2、npm run dev / build / serve 执行来源

其实 npm run dev 或者是npm run servenpm run xxx 并不是一定要这么写。
npm run XXX是执行Vue项目配置在 package.json 中的脚本,比如:

"scripts": {
  "serve": "vue-cli-service serve",
  "build": "vue-cli-service build",
  "lint": "vue-cli-service lint"
},

npm run xxx 中的 xxx 可以理解为键值对中的 key,实际上 run 的是在 package.json 里面 scripts 配置的 value;

比如,npm run serve 实际运行的是 vue-cli-service serve

而放在 3.0 以前运行的则是 node build/dev-server.js 文件;

这时候我们再来看上边的问题是不是豁然了呢, scripts 中并没有配置 dev ,所以控制台报了 [ missing script: dev ] 的错误 ;


3、小结

npm run xxx,并不是你想运行就运行的,只有在 package.json脚本中对scripts 配置了,才可以进行 run 的,所以不是所有的项目都能 npm run dev/serve

要了解这些命令做了什么,就要去scripts中看具体执行的是什么代码。

这里就像是一些命令的快捷方式,免去每次都要输入很长的的命令(比如 serve 那行)

一般项目都会有 build, dev, serve 等,所以起名,最起码要从名字上基本能看出来是干什么的。


参考:
npm run dev 还是 npm run serve