整日修碎片化学习“凡不凡”?来看看十几家大厂都是如何深入理解组件化架构的,不好意思,用力过猛!

18 篇文章 0 订阅
4 篇文章 0 订阅

前言

  • 组件化是 保持整个 App 可持续地进行高质量开发的基础,近年来也是业界一直在积极探索和实践的方向,在深入理解组件化架构的过程中,将不断考验你的技术深度与广度;
  • 实践中我还参考了十几家技术团队的解决方案(例如:美团、有赞、阿里等等),在这个系列里,我将总结我对于组件化的思考和实践。如果能帮上忙,请务必点赞加关注,这真的对我非常重要。

大厂解决方案参考

1 有赞微商城 IOS 端
  • 指出了业务模块化的基本演进:“混乱” -> “中介者模式”->“去中心化”
  • 梳理了模块间通信需求:UI 页面跳转、动作执行及复杂数据传输、一对多的通知广播;
  • 分享了“复杂数据传输”的处理办法:“复制粘贴代码” -> “下沉到common”

[图片上传失败...(image-e4fe5b-1632400813050)]

2. 有赞微商城 Android 端
  • 提出了 5 个调整方向:抽象基础模块、公共服务去中心化、业务模块服务化、抽象基础组件、单/多模块打包
  • 介绍了基于 3 个基础组件依赖和 1 个 Gradle 插件的落地方案

[图片上传失败...(image-f410ab-1632400813050)]

3. 蘑菇街 App
  • 提到了组件间通信的实现:URL 统跳、协议下沉(需要有一个公共的地方来容纳这些 public protocl)、隐式 Intent
  • 提到了组件生命周期管理:监听系统通知、ModuleManager 中手动遍历调用
  • 提到了组件版本管理与持续集成经验

[图片上传失败...(image-bfa1c7-1632400813050)]

[图片上传失败...(image-ad6458-1632400813050)]

4. 得到 App
  • 提到了组件生命周期、服务注册的实现
  • 提到了公共层定义组件服务、base层定义通用资源
  • 提到了 implementation 与 runtimeOnly 的代码 / 资源隔离效果;
  • 提到了 JIMU 插件的调试切换、智能配置功能;
  • 提到了 2 种调用组件声明周期的方法: javassist 和反射;
  • 提到了有序初始化组件的解决方案:StartUp、DAG

[图片上传失败...(image-20964e-1632400813050)]

5. 携程 App
  • 提到了使用数据总线或者 URL 总线实现页面和功能跳转
  • 提到了定制 Gradle 插件来定制化打包

[图片上传失败...(image-16e0c7-1632400813050)]

6. 支付宝 App
  • 介绍了基于 Bundle 和 mPaaS 打包插件的 Quinox 客户端框架,用于解决模块化和动态化两大问题;
  • 提到了解决资源 id 重复的解法:改造 aapt,为每个 Bundle 指定不同 packageId;

[图片上传失败...(image-c4f27d-1632400813050)]

7. 手淘 App
  • 提到了手淘 All In (聚划算、天猫、彩票)方案的隐患:性能、复用、稳定;
  • 提到了容器框架 Atlas 的工作原理;

[图片上传失败...(image-bc843f-1632400813050)]

[图片上传失败...(image-78153b-1632400813050)]

8. 爱奇艺 App
  • 提到了使用 Service 进行跨进程组件通信的缺点;
  • 介绍了组件化跨进程通信框架 Andromeda 的功能与核心原理;
9. 微信 App
  • 提到了微信架构演进:简单分层架构 -> 多进程架构 -> 多子工程并行开发架构;
  • 提到了基础工程存在中心化的问题:越来越多的代码/事件很“自然的”被下沉到基础工程;
  • 提出了重塑模块化的 3 个目标:改变通信方式、重新设计模块、约束代码边界
  • 提出了服务注册的通信方式
  • 提出了新颖的接口暴露方法:将文件后缀修改为.api(需配合include_with_api 命令)
  • 设计了模块生命周期:dependency()、configure()、execute()
  • 设计了 pins 工程结构,用于约束代码边界
  • 提出了组件化的考量问题:动态性、隔离性

[图片上传失败...(image-eb11-1632400813050)]

10. 美团 App
  • 设计了组件消息总线 modular-event
  • 设计了组件化路由框架 WMRouter

这份整理好的组件化强化实战资料就放在下方二维码中,有兴趣的可以自行查阅

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值