一、什么是 peerDependencies
peerDependencies 存在于 NPM 的 package.json 中,如果项目中依赖模块 X、模块 Y,模块 Y 又依赖模块 X,当模块 X 出现版本冲突的时候,则会打包出 X 的两份代码。在这个模块 Y 里面使用 peerDependencies 引入模块 X,这样当前项目和模块 Y 便会共用这个模块 X。
当在 peerDependencies 引入一个模块后:
- 当前的代码将与符合版本条件的模块和谐相处。
- 如何这个模块已经存在于项目的
node_modules中,什么也不提示。 - 如何这个模块不存在于项目的
node_modules中,警告用户缺少此模块,但是不自动安装。
注意: npm i 并不会自动安装 peerDependencies 里的模块,所以开发模块的需要在 devDependencies 同步添加相应模块。
二、什么场景下适合引入 peerDependencies
- 多份模块代码的重复加载易引发冲突。
- 依赖在项目中是可见的。
- 可以让开发者自己决定安装哪个版本。
业内应用:
"peerDependencies": {
"react": ">=16.9.0",
"react-dom": ">=16.9.0"
}
"peerDependencies": {
"vue": "^2.5.17"
}
三、案例
测试项目 test-project 为例,dependencies 为:
# test-project
"dependencies": {
"m1": "1.0.0",
"m2": "1.0.0",
"m-child": "1.0.0"
}
# m1@1.0.0
"dependencies": {
"m-child": "2.0.0",
}
# m2@1.0.0
"dependencies": {
"m-child": "3.0.0",
}
npm i 之后,实际的 node_modules 结构是这样的:
node_modules ├── m1 1.0.0 │ └── node_modules │ └── m-child 2.0.0 ├── m2 1.0.0 │ └── node_modules │ └── m-child 3.0.0 └── m-child 1.0.0
如上所见 m-child 的三个版本都下载到了本地,并且构建打包后包含了三份 m-child 的代码。
为了解决这部分重复代码,在模块 m1 和 m2 中引入 peerDependencies:
# m1@1.0.0
"peerDependencies": {
"m-child": ">=1.0.0"
}
# m2@1.0.0
"peerDependencies": {
"m-child": ">=1.0.0"
}
npm i 之后,实际的 node_modules 结构:
node_modules ├── m1 1.0.0 ├── m2 1.0.0 └── m-child 1.0.0
test-project、m1、m3 三个部分将和谐共用 m-child@1.0.0,构建打包后也只有一份 m-child。