npm包全局安装和局部安装

全局安装

安装位置

全局安装是将npm包安装在你的node安装目录下的node_modules文件夹中。在windows和mac中,全局安装的默认路径是不一样的。在mac中默认是安装到/usr/locla/lib中。在windows默认安装目录是C:\Program Files\nodejs,固然你也能够经过一下命令来查看全局安装路径。vue

// 查看全局安装路径
npm root -g

// 查看npm的基础设置
npm config ls

// 查看安装目录路径
npm config get prefix
复制代码

全局命令

npm包在全局安装以后,这个包的命令就会被注册到全局,你就能够直接在命令行中执行这个命令了。其实当你全局安装一个npm包以后,这个包被存放在/usr/locla/lib/node_modules或者C:\Program Files\nodejs\node_modules目录下。而在这个包的package.json文件中,在bin属性下配置的执行命令,会放在/usr/locla/bin或者C:\Program Files\nodejs文件中。当你在命令行执行这个命令,系统就会执行/usr/locla/bin目录下对应的文件。node

安装过程

以全局安装vue-cli为例,为你们简述一下安装过程。vue-cli

  1. npm install -g @vue/cli 安装vue包到/usr/locla/lib/node_modules

Mac系统

Windows系统

  1. 查找node_modules目录下的vue包的package.json中的bin属性。

img

  1. 在目录/usr/locla/bin或者C:\Program Files\nodejs查看vue命令的执行文件

Mac系统

Windows系统

  1. 在命令行中执行vue create vue-test

img

本地安装

安装位置

在特定项目中执行npm install xxx,那么这个包会被安装在这个项目的node_moduels目录下。可是若是你在这个项目中直接执行包中的命令,就会发现控制台报错,告诉你这个命令找不到。这时候有两个解决方法:npm

  1. 使用npx执行:npx出现主要解决的问题就是调用项目内部安装的模块,因此你能够在项目中执行npx 包命令
  2. 在package.json文件中配置:
"scripts": {
    "包命令": "包命令",
}
复制代码

原理: 在本地安装一个包以后,这个包的命令会被添加到项目的node_modules/.bin文件中。执行npm run 命令,package.json中的scripts会按照必定顺序寻找对应命令的位置,本地的node_modules/.bin也在寻找的清单中。因此本地安装的包的命令能够执行。json

相关文章
相关标签/搜索