当前位置: 首页 > 知识库问答 >
问题:

javascript - pnpm构建Monorepo项目的一些问题?

赵修诚
2023-12-20

场景如下:有三个项目A,B,C,这三个项目的关系如下图
image.png

  1. A是一个核心项目,其最终会使用Electron打成一个独立的项目A.EXE
  2. B项目是A项目的超集,在A的基础上会增加一部分功能,最终是一个B.WEB项目
  3. C项目是B项目的超级,在B的基础上也会增加一部分功能,最终也会使用Electron打成一个独立的项目C.EXE

经过一番调研,前端打算使用pnpm构建Monorepo架构,初步设想如下:

root├── package.json├── pnpm-workspace.yaml├── packages  ├── common    ├── package.json  ├── utils    ├── package.json  ├── A    ├── package.json  ├── B    ├── package.json  ├── C    ├── package.json

common用于存放那些共用的业务代码,a,b,c分别去依赖这个包。如果我把common包所需要vue、vue-router、pinia都安装到common里,然后a,b,c去依赖它,但是这个时候在a,b,c中导入vue就不行了,这跟我想的有点不一样哈(依赖不能传递吗?),所以我只能把它安装到根目录下。安装到根目录下倒是跑起来了,不知道这样可以吗?刚接触到这个,前端也不是很熟,求大佬指导
image.png

大致了解了Monorepo架构,初步选项使用较为简单的pnpm

共有2个答案

裴成文
2023-12-20
  1. 大体上没问题
  2. pnpm 因为依赖树解析的问题,不支持直接使用“依赖的依赖”,即 A 依赖 B,你安装了 A,可以使用 A,但是不能直接使用 B
  3. 所以最好的办法就是每个项目里单独安装一份 vue、vue-router 等
  4. 不过不用担心,pnpm 使用硬链接,所以不存在重复下载和安装的问题
支才
2023-12-20

对于使用pnpm构建Monorepo项目,有一些问题和注意事项需要考虑。

首先,关于依赖管理的问题,Monorepo架构允许你在多个项目之间共享和重用代码,同时也能够管理这些项目之间的依赖关系。在你的场景中,common包包含了共用的业务代码,而A、B、C项目分别依赖于这个包。通常情况下,依赖关系是可以传递的,即如果A依赖于B,B依赖于common,那么A也会间接依赖于common。但是,如果遇到无法导入vue的情况,可能是因为vue被安装在了根目录下,而不是在common包中。

为了解决这个问题,你可以尝试将vue、vue-router、pinia等依赖安装在common包中。这样,A、B、C项目只需要依赖common包,而不需要直接依赖这些依赖项。在common包中安装这些依赖项后,确保在common包的package.json文件中正确声明这些依赖项,以便其他项目可以正确地引用和使用它们。

另外,关于安装依赖项的位置,一般来说,将依赖项安装到根目录下是可行的,但是这样做可能会增加一些管理和维护的复杂性。如果你选择将依赖项安装到根目录下,确保在使用这些依赖项时使用相对路径或者别名来导入它们,以避免潜在的问题。

最后,对于Monorepo架构的构建和打包过程,你可能需要使用一些工具和插件来支持多项目构建和打包。你可以考虑使用一些现有的Monorepo工具,如Lerna、Yarn Workspaces等,它们提供了更高级的特性来管理多个项目之间的依赖关系和构建过程。根据你的具体需求和项目规模,选择适合你的工具和插件来构建和打包你的Monorepo项目。

 类似资料:
  • pnpm的monorepo问题, packages: 'main' 'web/**' 'common' 'common2' common的package.json 在main文件里面pnpm -F main add common 但是添加的包,不是本地的,这个是什么问题 改动common的version版本号,子项目不能以0开头的版本号, pnpm -F main add @project/com

  • 为了定义一个多项目构建, 你需要创建一个设置文件 ( settings file). 设置文件放在源代码的根目录, 它指定要包含哪个项目. 它的名字必须叫做 settings.gradle. 在这个例子中, 我们使用一个简单的分层布局. 下面是对应的设置文件: Example 7.11. 多项目构建 - settings.gradle file settings.gradle include "s

  • 我试图建立我的项目,但我不能。 致以最诚挚的问候

  • 请问在创建monorepo时如何进行本地开发调试,我了解到创建monorepo项目的两种方式为pnpm、npm的workspace。 我创建了一个示例代码库 https://github.com/jervainy/demo-monorepo.git, 有两个工程,lerna-workspace-demo 采用npm workspace方式创建的monorepo项目;pnpm-workspace-d

  • 开始 建构流程是整个项目最核心的地方之一,通过我们所熟知的 webpack,完成了 template 转换为 wxml 和 样式转换优化以及其他的若干代码的拼接压缩混淆等操作,最终使之可以运行在微信小程序的环境中。 如果你不了解什么是 webpack, 可以查看 webpack文档 。 用一个图来描述: app.vue & main.js ┌---------┐

  • 我在构建项目时遇到以下错误。我怀疑Butterknife库是一个原因,因为我通过它启用了注释。我们是否需要任何特殊的配置来包括butterknife和Ant build?如果你有任何建议,请告诉我。 [javac]错误:错误的服务配置文件,或在构造处理器对象javax时引发异常。注释。处理。处理器:提供者匕首。内部的科德根。无法实例化ProviderProcessor:java。lang.NoCl