当monorepo中的包具有对等依赖时,如何在开发过程中将这些依赖关系提供给它们?
例如,/packages/namespace/alpha/的一个包可能在其package.json中有一个devDependency of styled-components。
可能的备选方案:
package.json中安装包(使用yarn link时模块解析可能出现问题)。我用的是Lerna的纱线工作区。
发布于 2020-04-13 12:06:47
纱线工作区应该在根node_modules中安装几乎所有依赖于节点模块分解算法的东西。这就是你在备选方案2中所描述的。
所以,基本上在大多数情况下,它应该是有效的。当某些工具依赖于它自己的分辨逻辑或存在某些依赖项的不同版本时,可能会出现这些问题。
选项1是一种非常常见的方法,但正如您所说,它增加了维护成本。您可能需要跟踪此类依赖项,并将其标记为外部依赖项,以避免将它们包含到库的构建版本中。
有可能的解决办法。例如,角建议使用TS paths选项。你也可以在没有打字稿的情况下做同样的事情,例如,创建React 使用jsconfig.json。或者您可以使用类似于此汇总插件的方法,它可以基于peerDependencies自动添加外部元素,因此您也可以安全地将它们作为devDependies列出。
这两个选项在lerna问题中都被认为是合法的。
另一种选择是安装对等依赖项,目前还没有官方的解决方案。有安装对等点cli包可以与npm和yarn一起工作。有一个用于热特征请求的yarn。有一个向npm v7添加此特性的计划,实际上npm在v3之前就这样做了。
总之,没有一刀切的解决方案,你需要明白你想得到什么,你可以为此牺牲什么。
更新(2020年12月14日)- NPM 7安装对等Dec
正如我在初始答案中提到的,npm默认实现了安装对等依赖关系。详情请参阅RFC。
https://stackoverflow.com/questions/58027193
复制相似问题