前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[译] Node 模块中的 peer dependencies 是什么?

[译] Node 模块中的 peer dependencies 是什么?

作者头像
江米小枣
发布2020-06-15 19:48:19
1.8K0
发布2020-06-15 19:48:19
举报
文章被收录于专栏:云前端云前端

原文:https://flaviocopes.com/npm-peer-dependencies/

在某些 package.json 文件中,你可能见到过一些这样的配置行:

代码语言:javascript
复制
{
  //...
  "peerDependencies": {
    "libraryName": "1.x"
  }
}

dependenciesdevDependencies 常见,而 peerDependencies 并不是。

dependencies 是你的项目所依赖的包。

devDependencies 是开发阶段所需要的包。比如说像 Jest 这样的测试框架或 Babel、ESLint 等其他库。

在以上两种情况中,当你安装一个包时,其 dependencies 和 devDependencies 会被 npm 自动安装。

peerDependencies 则有所不同,它们不会被自动安装。

当一个依赖项 c 被列在某个包 b 的 peerDependency 中时,它就不会被自动安装。取而代之的是,包含了 b 包的代码库 a 则必须将对应的依赖项 c 包含为其依赖。

如果运行 npm install 时找不到该依赖,npm 会作出警告,正如例子中所示:

a/package.json

代码语言:javascript
复制
{
  //...
  "dependencies": {
    "b": "1.x"
  }
}

b/package.json

代码语言:javascript
复制
{
  //...
  "peerDependencies": {
    "c": "1.x"
  }
}

因此,在包 a 中,必须添加 c 作为一个依赖项,这样当你安装 b 包时,npm 就不会告警了(代码运行时也不会失败):

a/package.json

代码语言:javascript
复制
{
  //...
  "dependencies": {
    "b": "1.x",
    "c": "1.x"
  }
}

要注意依赖项的版本必须是兼容的,如果一个 peerDependency 被标为 2.x,你就不能安装 1.x 或其他不兼容的版本。该规定遵循 https://flaviocopes.com/npm-semantic-versioning/ 标准。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-02-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 云前端 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档