您的位置:58编程 > 4.1分清全局安装与本地安装哪个好 4.1 分清全局安装与本地安装

4.1分清全局安装与本地安装哪个好 4.1 分清全局安装与本地安装

2023-03-18 15:33

4.1分清全局安装与本地安装哪个好 4.1 分清全局安装与本地安装

4.1分清全局安装与本地安装哪个好

全局安装和本地安装都是Node.js的安装方式,但是它们之间有很大的不同。全局安装指的是将Node.js安装到系统中,以便所有用户都可以使用;而本地安装指的是将Node.js安装到特定的文件夹中,只能被特定的用户使用。

那么,4.1分清全局安装与本地安装哪个好呢?这要看你想要达到什么目的。如果你想要一个可以被所有用户使用的Node.js环境,那么全局安装就是你的选择。如果你想要一个只能被特定用户使用的Node.js环境,那么本地安装就是你应该选择的。

此外,全局安装会占用大量系统资源,耗费时间并且不易于管理。因此,如果你想要一个快速、易于管理、不会占用太多系统资源的Node.js环境,那么本地安装就是你应该选择的。

// 全局安装 
$ npm install -g  
 
// 本地安装 
$ npm install  

4.1 分清全局安装与本地安装

刚学习 npm 的时候,官方教程在介绍 -g 参数时是这么描述的:“加上 -g 参数是全局安装,否则本地安装”。这种说话说一半的感觉真的很让人讨厌,什么是全局什么是本地完全没有介绍。以至于后来很长一段时间才搞明白这个概念。虽然是个小知识点,但我觉得有必要在学习模块安装之前先介绍一下。

1. 全局安装和本地安装都安装到了哪?

官方文档:使用 ​-g​ 安装的模块为全局安装,否则为本地安装。

使用​ -g​ 安装全局模块

$ npm install express -g

不使用 ​-g​ 安装本地模块

$ npm install path

那么问题来了,全局模块和本地模块都安装到哪了?

  • 全局模块安装路径
// 输入指令查询全局模块安装路径
$ npm list -g --depth=0

查询全局模块安装路径

  • 本地模块安装路径

本地模块安装路径

本地模块安装在当前目录下的 ​node_modules ​目录下。

以上图为例:安装本地模块的当前目录是 D:code,那么在该目录下会自动创建 ​node_modules ​目录(如果之前有这个目录就不会创建了),在 ​node_modules ​目录下就可以找到刚才安装的 ​path ​模块了。

2. 全局安装和本地安装的包有啥区别?

我们将一些包全局安装,另一些包本地安装,二者有什么区别呢?

官方的解释是:

  • 全局安装的包直接安装到计算机中,只需安装一次,以后在计算机的任何位置都可以使用这个包;
  • 看本地安装包安装到哪儿可以知道本地包是安装在当前目录下的,也就是说,只有在当前目录下才可以使用安装的本地包。比如上面贴的图片中安装的本地包 path,只有在 D:code 目录下才能使用这个包,换做其它任何目录是不能使用它。

全局安装与本地安装

总结:全局安装安装一次重复使用,本地安装使用什么安装什么。

3. 哪些包我应该全局安装,哪些包又应该本地安装?

既然全局安装安装一次就可以重复使用,那么干嘛不是所有包都使用全局安装呢?

回答上面那个问题之前,先来解释下另一个问题:哪些包应该全局安装?

约定俗成的,对于那些提供命令行工具的包进行全局安装,其它包本地安装。

举例说明:

  • 安装 ​dva-cli ​包
$ npm install dva-cli -g

使用命令行工具输入指令 ​dva new​ 创建 dva 脚手架

$ dva new dva-demo

像这种能提供指令的包通常进行全局安装

  • 安装​ eslint​ 包
$ npm install eslint -g

使用指令​ --init​ 设置一个配置文件

$ eslint --init

像这种能提供指令的包通常进行全局安装

总结:不用管上面两个案例的指令具体是什么,只要提供指令的包都建议使用全局安装;其它包打包是提供一个功能,用于解决某一需求,建议安装成本地包。

你可能还会困惑,我刚开始学习 npm 还不知道哪些包是否提供指令,应该怎么办?没有关系,不知道的全部安装成本地包,在实践中如果发现这个包提供指令,也可以使用后面章节会提到的卸载包,再重新进行全局安装即可。


阅读全文
以上是58编程为你收集整理的4.1分清全局安装与本地安装哪个好 4.1 分清全局安装与本地安装全部内容。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
相关文章
© 2024 58编程 58biancheng.com 版权所有 联系我们
桂ICP备12005667号-32 Powered by CMS