3

我正在维护一个package-A依赖另一个 NPM 包(package-B)来运行的 NPM 包(可以说它)。因此,我需要将该包作为对等依赖项添加到 中package.json,以便 npm 和用户可以确保一切正确。

问题是,package-B使用预发布版本控制。我很清楚它使用了错误的 semver,但我还无法更改公司政策。同时会强制使用正确的版本控制。语义是这样的:

  • 1.0.1-alpha.X -> 用于测试和前沿内容的不稳定版本
  • 1.0.1-beta.X -> 对于每个看似稳定的版本(如 rc)
  • 1.0.2 -> 当包准备好生产时。

所以基本上,当有另一个生产版本时,补丁版本会增加。

案例:由于版本控制,我需要将除主要包之外的每个包都包含为对等依赖项,以及预发布版本。

需求基本上是所有东西,包括碰巧与对等依赖一样重要的^1.0.0预发布1

  • ^1.0.0-> 不包括预发布
  • ^1.0.0 || >=1.0.0-beta.X-> 不包括例如1.0.1-beta.1
  • *-> 不包括预发布
  • ^1.0.0 || >=1.X.X-beta.X-> 不工作。

在 semver 上,有一个名为的参数--include-prerelease,我认为它可以满足我的需要,显然特定于 semver 命令。

reactNPM 上的包具有类似的版本控制系统,并正确使用了预发布。例如,它16.0.016.0.0-alpha.116.6.0-alpha.0。我基本上需要将所有这些都包含在一个范围内。

免责声明:当发生重大更改时,会更改次要版本。再一次,我很清楚这个版本控制不符合 semver 规定,不幸的是,建议它不会解决手头的问题。

4

1 回答 1

2

https://classic.yarnpkg.com/en/docs/dependency-versions#toc-pre-release-tags

如果比较器包含带有预发布标签的版本,它将仅与具有相同major.minor.patch版本的版本匹配。

您只能包含特定版本的预发布。

>=1.0.0-beta包括1.0.0-beta.X,但不1.0.1-beta.X

您可以在https://semver.npmjs.com/上使用 semver 预发布范围 查找@artsy/reaction他们有一堆预发布的包

于 2021-08-13T14:40:08.550 回答