同一个项目具有多种不同的发行版,应该如何管理代码与产物?

66 天前
 mouyase
比如我手上现在有一个 App 项目,现在同时有国内版和国外版两种版本,以及 android 和 ios 两个平台,所以一共具有 4 种不同的发行版,如何才能正确的管理和维护项目的代码和产物呢?



该项目具有以下的特性



- 是使用 ReactNative 开发的 App 项目,所以 android 和 ios 的代码是在同一个项目里

- 国服和国际服使用了不同的原生 SDK ,因此原生代码不同

- 国服和国际服使用了不同的包名,图标,签名等

- 国服和国际服使用了不同的服务端

- 国服和国际服有大量相同的逻辑代码和相同的页面 UI 组件,但在各种各样的细节地方有区别,例如同一个组件在两个服调用的接口不同,数据结构不同

- 两个服因为服务端不同,导致服务端的接口版本也不同,发版时间也不同



暂时想到的好像就只有这么多了,现在项目是所有代码都在一起,通过不同的环境变量来判断,项目里的状态管理已经一团糟了,经常改了国际服的逻辑,结果导致国服版本出问题之类



还有个问题就是两个服用了不同的 npm 库,最后导致打出来的原生包包含了两个服所有的 sdk 文件,产物体积变得非常巨大



不知道各位大佬有没有遇到类似的问题,有没有好的解决方案
875 次点击
所在节点    问与答
5 条回复
snipking
66 天前
简单解:app 分成两个代码库,相同的代码维护两遍,复制粘贴而已
一般解:app 分成两个代码库,抽象组件库供 app 使用,非组件库的相同代码维护两遍,复制粘贴而已
进阶解:按 DDD / Clean-Architecture 思想重构,将现在通过状态控制的逻辑抽象为接口及实现,完善单元测试
mouyase
66 天前
@snipking 现在一个问题是相同的代码和不同的代码是分散的分布于各种地方,做不到解耦,如果复制粘贴可能会导致一侧的改动覆盖另一侧
snipking
66 天前
@mouyase 只是单纯的复制粘贴的话,你需要的是一只猴子而不是程序员
kongkx
65 天前
拆成两个项目,公共部分做 submodule 。 核心逻辑层需要做抽象, 各自项目在项目内结合 sdk 做核心数据库的 adapter 或者 utils 。 能复用的 UI 也是独立成库。
mouyase
63 天前
@kongkx 感谢提供参考

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1056927

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX