nodejs中package.json中的依赖必须每一个项目都有本身的node_modules文件夹,而没法在多个项目之间共用一套node_modules(像Java中的Maven那样)。前端
依赖管理是每一个现代语言的标配。依赖管理和打包工具是两个概念,npm是依赖管理,webpack是打包工具。
在Java中,maven既能实现依赖管理又能实现打包。node
何为依赖管理?
依赖管理说白了就是构建一个有向无环图。项目A依赖项目B,项目B依赖项目C,那么当你的项目依赖A的时候,依赖管理工具会自动让你的项目依赖B和C。
要想构建有向无环图,最关键的是要将项目转化为有向无环图中的结点。因此对于项目每每有description,做者信息,版本信息等额外信息。
依赖管理最难解决的问题就是版本问题。库A依赖库B,库C也依赖库B,可是库A跟库C所依赖的库B不是同一版本,若是库B的这两个版本兼容还好,若是不兼容就坑大发了,这是无解的问题。python
下面说说Java,Python,Node三种语言中的依赖管理。webpack
Node这种node_modules文件夹的方式有利有弊。
最明显的坏处是:git
最明显的好处是:web
我认为不一样语言对于依赖的定位不一样。Java中的库是严谨的库,Python中的库是玩具同样、随手写就的库,Node里的库是代码片断同样的库。Node里面的库既然定位就是代码片断,那么固然要将代码片断跟你的项目放在一块儿了,这样才方便你修改这些代码片断。但是随着时间推移,node中的库愈来愈大、愈来愈严谨,这种对待代码片断的方式就有些很差了。npm
总结:这是一种设计,这种设计有利有弊。json
如下是知乎上的回答片断:maven
全局依赖的惟一好处就是省了硬盘空间。这种省毫无心义。首先若是你要为几十几百兆的硬盘空间斤斤计较,那么也许你已经穷得不适合作开发。其次若是须要支持全局多版本也省不了多少。至于有人说的,每次npm install时间太长,我认为这也不是个事。npm install又不是每天搞,并且只是第一次全新checkout的时候比较慢,之后都是增量更新。实在嫌慢(好比由于防火墙的缘由),能够把node_modules一块儿提交到git里去。
其实我以为彻底能够作成全局的,依赖模块都装到公共目录,每一个项目在 npm install 时用符号链接把每一个模块对应的版本目录连过来,或者干脆就在 require() 时去全局的模块目录里去找,这样也不麻烦。实际上我团队就包了这样一个命令,安装时是全局安装,项目 init 时符号链接过来,很省时间和空间。但 npm 没有这么作,我以为一是在一开始没考虑到,后面也就很差改了。实际上就连 node_modules 模块多层嵌套致使路径过长的问题,也是一开始设计时没考虑周全,到了 npm3 才改。工具
Java在20年前就解决这个问题了,而后后面抄的语言没有一个彻底抄对的