组件化入门

在开发应用时我们会发现其实很多功能是相似的,而如果每开发一个项目都要重新去编写相关的代码的话会很费时间,如果把每个单独的功能都封装成一个组件,每个业务都封装成模块的话就可以有效的提高开发效率,以及代码的复用率。

  • 组件:单一的功能组件,如视频组件,支付组件,路由组件,每个组件都能单独抽出来制作SDK
  • 模块:独立的业务模块,如直播模块,首页模块,即时通信模块,模块可包含不同的组件。

在搭建新工程时可考虑以下问题。

  • 将公用的代码提取出来放作为基础库 Base module
  • 将单独的功能封装到 Library module 中
  • 多 module 划分业务和基础功能

关于聚合和解耦

自打入坑面向对象编程时听到最多的一句话就是高内低耦合,现在搭建工程也可以用到这个思想。

  • Android Studio 通过依赖的方式为每个 module 之间提供了沟通和交流的渠道从而形成聚合。
  • 当一个模块和非常多的模块交流时,如果有一天我们需要换掉这个模块,移除它和别的模块的依赖关系那么后果将是灾难性的,所以需要通过解耦来找到一个为移除或者替换某个个体的行为付出最少的代价的方案。
聚合和解耦是项目架构的基础,设计模块时应思考以下问题。
  • 如何让每个个体产生最大的作用
  • 如何让个体间的交流通畅
  • 如何让每个个体付出最小的消耗来完成任务,并产生更大的集体利益
  • 如何统筹更大的集体利益

如何使用依赖

  • Library dependency 可依赖第三方库(本地或者网络的)
  • Jar dependency 引入 lib 文件夹中所有 .jar 后缀的文件,还能引用 .aar 后缀的文件。
  • Module dependency 库依赖

下面演示建一个基础库并在项目中依赖它

AndroidManifest.xml 文件

  • AndroidManifest 是 Android 项目的声明配置文件,用来声明配置四大主键 Activity、Service、BroadcastReceiver、ContentProvicer ,以及自定义的 Application。
  • 每个 module 都有一份配合的 AndroidManifest 文件来记载配置信息。
  • 最终生成 App 的时候只有一份 AndroidManifest 来指导 App 应该如何配置,这是会将每个 module 中的 AndroidManifest 合并成一个。

AndroidManifest 属性汇总

编译主 module 时会将这些功能 module 重新编译,而每个 module 可单独编译成一个 aar 文件

使用时直接将编译好的 aar 文件拷贝到新的工程里就可以直接用了。

Demo地址

参考

  • 《Android 组件化架构(苍王)》
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容