放下叮铛这个项目也有一段时间了,现在写下这篇文章来分享一下组件化开发的一些心得。
- 什么是组件化开发?
组件化开发是把各个关键的组件或功能分拆成一个单独的库来开发维护。
为了降低项目的耦合度,复用性更高,可以脱离主工程开发而采用的一种开发模式。 - 组件化开发有什么好处?
- 在做比较大的项目的时候,可以更加方便地管理各个功能。
- 其次在同时需要上几个大功能的情况下,如果都依赖于主工程去做开发,会出现两个功能上线的时候有冲突的问题。
- 另外,某组件若依赖于主工程开发,则主工程有逻辑变动的时候,影响到组件的地方也需要人去维护。而功能库则是只开放api给主工程使用,不会直接往库里添加某些专用的业务代码。若有需要,也是另外开放一个api供主工程使用。
如何设计一个组件化架构
一个优秀的组件化架构应该是能把所有功能分拆到各个库,而主工程只是一个桥梁或者说是容器,去装载贯通各个功能库。库与库之间可以有依赖关系,但是不能相互依赖。比如说一个项目里面有最基本的网络请求类,图片加载类,约束类,公用方法类等...这些类可以抽出来作为BaseLibrary,即基础库。(有些工程师可能会觉得这些基本的类可以保留在主工程里,那么开发别的库需要用到这些类的时候还是变相地依赖了主工程。)
下面列举一下一些可能可以抽出来的功能库:
- 基础库(网络请求类,布局类,公用方法类,基础模型类)
- 视图库(基础视图类,特效视图类,动画类)
- 分享库(集成的第三方分享功能如微信、QQ、微博等)
- 支付库(集成的支付手段如支付宝、微信、银联、IAP等)
- 音频库(集成音乐播放管理)
- 视频库(集成播放、播放器、直播等音视频相关的库,也可和音频库合并成音视频库)
- 用户库(集成登录、修改信息、储存用户信息)
- 地图库(定位、反编码坐标、地图视图)
- 活动库(各种需求活动产生的一次性类库)
还有其他一些根据不同APP需求功能来分拆的库例如:
电商类的商品库、购物车库
阅读类的阅读库
地图类的导航库
资讯类的资讯库、评论库
等等。。。
相比臃肿的大工程,细分后的组件化工程使用和维护起来也是非常简单。组件化主要用到的工具便是cocoapods。依靠cocoapods可以方便地管理本地的代码和依赖的第三方库,还可以把组件化的库打包成framework方便使用。
相关博客:
使用podpackage打包工程库: https://graydang.github.io/2018/06/15/podpackage
优雅地使用Cocoapods:https://graydang.github.io/2018/06/15/cocoapods