既然npm run dev执行了vite命令,那我为何不直接输入vite?

问题背景

我成功地把代码模板推给了团队:Ctrl ACV工程师的提效之路------plop自动生成代码

队友在用的时候,按照我文档里写的,在执行plop命令的时候报错了,提示没有这个命令。针对这个问题,我做了一些探索。

首先新开一个文件夹,在这里运行命令去查询plop安装的版本:

bash 复制代码
plop -v
4.0.0

既然这个命令没报错,说明plop这个是全局可用的,查找node的安装目录AppData\Roaming\npm,果然发现了这个命令。因为我的plop用npm install =g plop安装过,所以不会报错,但是别人没有全局安装。

问题的解决方案之一就是让队友全局安装。

但是我们项目也本地安装了plop,难道这个是不生效的吗?

我在我的本地项目中查询plop安装的版本:

bash 复制代码
plop -v
CLI version 4.0.0
Local version 4.0.1

发现有一个Local version 4.0.1,这个就是我们在执行npm install plop -D的时候安装的(package-lock.json中能看出来)。

无独有偶,我发现项目的启动命令npm run devvite也是有同样的问题:

vbnet 复制代码
dev: 'vite'

npm run dev实际上是执行了vite,为什么我们要这样写?运行项目的直接输入vite不是更省力吗?

如果我直接输入vite,也会有报错,提示命令不存在。

npm run dev确实执行了vite,但是这里的vite命令,并不是直接在全局环境下去找,而是在node_modulesbin目录下去寻找执行语句,bin目录又指向了node_modules/vite/bin

过程梳理

  1. 在发布npm包的时候,package.json中可以定义bin,指向一个执行文件,在执行npm install的时候,自动在node_modulesbin目录下新增可执行文件。

  2. 在执行npm run XXX的时候,首先是去node_modulesbin目录下寻找是否有该命令,如果有的话,根据该命令,定位到执行文件,然后往下执行;如果找不到,就去node的全局环境找命令;再找不到,就会报错。

最终处理方案

package.json中新增一个scripts,

json 复制代码
{
    "scripts": {
        "create": "plop",
    }
}

使用方法:

shell 复制代码
npm run create [XXX] [XXX]

这样就不用全局安装plop了。

自己发布npm包时如何配置命令?

需要在package.json中定义bin

相关推荐
Mike_jia5 分钟前
OpenDeRisk:AI 原生风险智能系统 ——7*24H 应用系统AI数字运维助手(AI-SRE)
前端
朱穆朗14 分钟前
electron升级到33.0.x版本后,devtools字体的修改方法
前端·javascript·electron
IT_陈寒23 分钟前
Java 21新特性实战:5个必学的性能优化技巧让你的应用提速40%
前端·人工智能·后端
HarrySunCn27 分钟前
大夏龙雀DX-CT511N-B实战之路-第1步
前端·单片机·物联网·iot
未来之窗软件服务35 分钟前
幽冥大陆(七十七)C# 调用 中文huayan-medium.onnx —东方仙盟练气期
前端·ui·c#·仙盟创梦ide·东方仙盟
古茗前端团队37 分钟前
用 NAudio 做一个音频播放器及原理
前端
wei yun liang43 分钟前
4.数据类型
前端·javascript·css3
奥升新能源平台1 小时前
奥升充电平台OCPP协议解析
前端
JinSo5 小时前
我的2025年度总结:EasyEditor
前端·程序员
喝拿铁写前端9 小时前
前端开发者使用 AI 的能力层级——从表面使用到工程化能力的真正分水岭
前端·人工智能·程序员