这种情况下,npm 会如何管理包?
我在 node_modules 的目录下面,只看到了 D 的最新版本,即 C 依赖的 D 的版本文件,B 依赖的低版本的 D 看不到。这个是咋回事么?
然后在 yarn.lock 文件里,D 的两个版本都有......
1
foolnius 2022-03-17 17:58:44 +08:00
B 包里面有一个 node_modules ,C 包里面也有一个 node_modules
|
2
FreshOldMan 2022-03-17 18:01:15 +08:00
npm 的正常操作,两个版本的 D 会都下载下来
|
3
yazoox OP @FreshOldMan 下载下来后,放在哪里?
|
4
libook 2022-03-17 18:05:15 +08:00
很多包是依赖模糊版本,比如“~”开头的和“^”开头的都是会自动选择一个区间范围,如果 B 和 C 依赖的 D 版本区间有交集,是可以共用同一个版本的 D 的。
|
5
yazoox OP 找到一篇文章,基本看明白了。“扁平化” 和 “依赖提升”
https://juejin.cn/post/6932046455733485575 |
6
feimo1996 2022-03-23 11:59:30 +08:00
这种情况如果 D 的两个版本没啥兼容性问题那就还好。
|
7
Makabaka01 2022-06-19 10:26:57 +08:00
你用的是 yarn 的话,B 、C 如果依赖了同一个版本的 D ,那么 D 会和 B 、C 同级别出现,就像这样:
``` node_modules - D - B - C ``` 如果不同的话,那么 yarn 可能会将其中一个提升到同级别,然后另一个包下会出现一个 node_modules ,就好象这样: ``` node_modules - [email protected] - B - C - node_modules - [email protected] ``` yarn 会尽可能的去打平依赖,除非版本不同。 |