npm 全局安装和局部安装的区别

上图是从网上找的webpack 安装的步骤,咱们看到除了要全局安装以外,还须要本地安装,那么这二者有什么区别呢?
本文以Windows平台上作测试,以webpack为示例作教程css

什么是全局安装?

安装位置

全局安装方式是键入命令:npm install webpack -g 或 npm install webpack --global,其中参数-g的含义是表明安装到全局环境里面,包安装在Node安装目录下的node_modules文件夹中,通常在 \Users\用户名\AppData\Roaming\ 目录下,可使用npm root -g查看全局安装目录。node

 

 

调用方式

全局安装后能够供命令行(command line)使用,用户能够在命令行中直接运行该组件包支持的命令。webpack

 

 

上图列出了一部分关于webpack支持的命令行,若是不了解的话,可使用 webpack -h 来查看它所支持的全部的命令;git

什么是本地安装?

安装位置

本地安装方式是键入命令:npm install webpack 或 npm install webpack --save-dev等,其中参数--save-dev的含义是表明把你的安装包信息写入package.json文件的devDependencies字段中,包安装在指定项目的node_modules文件夹下。github

 

 

调用方式

本地安装后能够直接经过require()的方式引入项目中node_modules目录下的模块,以下示例,本地安装后直接在webpack.config.js中require('gulp')。web

 

 

为何全局安装还要本地安装?

仅仅全局安装够吗?

1.在js实例代码中,默认下node.js会在NODE_PATH和目前js所在项目下的node_modules文件夹下去寻找模块,所以,若是只是全局安装,不能直接经过require()的方式去引用模块,须要手动解决包路径的配置问题,固然你也能够复制全局安装的node_modules文件夹到项目下,还有办法能够选择将环境变量的NODE_PATH设置为C:\Program Files\nodejs。npm

2.对于包的更新很差管理,可能你须要为每一个包从新命名,如gulp@3.8.一、gulp@3.9.1...,为了区别不一样项目使用指定的包,保证模块之间的相互依赖(这块下面会介绍),区别每一个项目正常运行。json

所以,不推荐只全局安装。gulp

本地安装的重要性

最先的node.js/npm其实是全局的,包括如今还兼容NODE_PATH,可是不能支持全局多版本,因而nodejs团队改为本地安装的方法可能就是为了保证不一样版本包之间的相互依赖,什么意思呢,举个例子wpdemo组件中相互依赖的包就有不少个测试

 

 


其中依赖包的指定版本号以下,不可轻易去修改,由于不一样版本包对应依赖包的版本的功能有所差异,若是修改指定的版原本运行wpdemo,就可能会编译出错等bug。

 

 

依赖

再举个例子:

包版本为:A(0.0.1)依赖B(0.0.2),B(0.0.1)依赖C(0.0.3) 一段时间原做者更新后, 包版本为:A(1.0.1)依赖B(1.0.0),B(1.0.0)依赖C(1.0.0) 

每一次的更新可能带来不同的功能,在多人合做、发布模块到npmjs社区、上传到github给其余人使用时,保留模块的版本信息可用于下载指定的版本号显得特别重要。
本地安装可让每一个项目拥有独立的包,不受全局包的影响,方便项目的移动、复制、打包等,保证不一样版本包之间的相互依赖,这些优势是全局安装难以作到的。
另外,据node团队介绍,本地安装包对于项目的加载会更快。
有优势也少不了缺点,如每次新项目都要本地安装所依赖的包,安装包时间相对较长,一来是包太大致使下载慢;二是浪费了硬盘空间,不过如今电脑硬盘动不动就几个T,你还会在乎节省这点空间吗?

 出处:http://peunzhang.cnblogs.com/

相关文章
相关标签/搜索