之前开发了一个npm的包。在实际应用中发现了一个问题。如果你想要直接执行这个包的命令,那么你就需要全局安装这个包。如果你只是局部安装,且没有在package.json文件中配置的话,就会提示该命令无法找到。这是为什么呢?今天就来为大家介绍一下全局安装和局部安装到底是做了什么,
全局安装
安装位置
全局安装是将npm包安装在你的node安装目录下的node_modules文件夹中。在windows和mac中,全局安装的默认路径是不同的。在mac中默认是安装到/usr/locla/lib
中。当然你也可以通过一下命令来查看全局安装路径。
// 查看全局安装路径
npm root -g
// 查看npm的基础设置
npm config ls
// 查看安装目录路径
npm config get prefix
如果是公共电脑你不想将npm包安装在默认目录下,那么你可以通过命令来修改安装路径。
// 修改安装目录路径
npm config set ''
如果在全局安装中遇到权限问题报错,你需要修改文件夹的权限,执行一下命令。
sudo chown -R $(whoami) $(npm config get prefix)/{lib/node_modules,bin,share}
全局命令
npm包在全局安装之后,这个包的命令就会被注册到全局,你就可以直接在命令行中执行这个命令了。其实当你全局安装一个npm包之后,这个包被存放在/usr/locla/lib/node_modules
下。而在这个包的package.json文件中,在bin
属性下配置的执行命令,会放在/usr/locla/bin
文件中。当你在命令行执行这个命令,系统就会执行/usr/locla/bin
目录下对应的文件。
安装过程
以全局安装vue-cli为例,为大家简述一下安装过程。
npm install -g @vue/cli
安装vue包到/usr/locla/lib/node_modules
。


/usr/locla/bin
中。

vue create vue-test
,命令被识别。

本地安装
安装位置
在特定项目中执行npm install xxx
,那么这个包会被安装在这个项目的node_moduels
目录下。但是如果你在这个项目中直接执行包中的命令,就会发现控制台报错,告诉你这个命令找不到。这时候有两个解决方法:
- 使用npx执行:npx出现主要解决的问题就是调用项目内部安装的模块,所以你可以在项目中执行
npx 包命令
。 - 在package.json文件中配置:
"scripts": {
"包命令": "包命令",
}
原理: 在本地安装一个包之后,这个包的命令会被添加到项目的node_modules/.bin
文件中。执行npm run 命令
,package.json中的scripts会按照一定顺序寻找对应命令的位置,本地的node_modules/.bin
也在寻找的清单中。所以本地安装的包的命令可以执行。