基于ARouter的Android组件化实现

网上组件化的文章不少,我本人学习组建化的过程也借鉴了网上先辈们的文章。但大多数文章都从底层的细枝末节开始讲述,由下而上给人一种这门技术“博大精深”望而生畏的感受。而我写这篇文章的初衷就是由上而下,但愿别人在阅读的过程当中可以以为“组件化原来也就是这几个东西”的感受。
####首先咱们来看一下组件化项目和传统项目的区别git

######在传统的项目里
咱们一般状况下会有一个commonLib的Libary模块和一个app的application模块,业务中的逻辑都写在app中各个功能模块放到不一样的包下。这样作有如下几个主要的缺点:
1.不管分包作的再好,随着项目的增大,项目会逐渐失去层次感,别人来接手的时候会很吃力。github

2.咱们在debug一个小功能的时候每次修改代码都须要从新build整个项目,这样显的很不合理(不知道AS的热部署有没有解决这个问题)app

3.多人联合开发在版本管理中很容易出现冲突和代码覆盖的问题
######在组件化项目中
除了有commonLib和app模块外,咱们按照功能划分各个业务组件模块(eg:×××能够划分出chat,contract,find,mine四个大模块),以前的包变成如今的模块,增长了层次感;每一个功能模块能够单独编译,加快了编译速度,也为提供单元模块测试提供了支持;多人开发只负责本身的模块,直接避免了版本管理的冲突。框架

图1-0组件化基本项目结构图

######在明白了组件化为咱们解决的主要问题后咱们来看看须要怎么作
初步实现组建化其实咱们最终要解决的问题就只有2个:
######1.设置模块之间的依赖,且使得业务模块可单独编译--经过配置gradle便可解决
######2.业务模块之间的页面跳转以及通讯--使用阿里开源的ARouter便可解决ide

######接下来咱们具体来看一下如何操做
######首先来看一下模块间依赖的问题
######咱们能够参照×××的四个模块(chat,contract,find,mine)来配置
首先咱们项目基本结构以下:组件化

图1-1项目结构

咱们一共须要建6个module,除了4个功能模块外还有一个基本的common库和一个做为启动的application。学习

在建好项目后咱们须要给4个module配置一个是否单独编译的开关:
图1-2单独编译各个模块的开关测试

关于开关的配置位置这是一个问题,咱们把它添加在gradle.properties文件中,这样咱们每次修改值的时候就能够触发gradle的从新构建,便于咱们单独编译module。gradle

咱们单独编译的开关配置好了,如今咱们来配置6个module之间的依赖关系:ui

图1-3app和功能lib的基础依赖

首先,为了方便各个module之间的交互咱们借用了阿里的充分ARouter库,因此在每一个非common的库(包括主Application)中我都强烈建议加入对ARouter和commonlib的依赖。

其次,4个功能模块库咱们要为它装上咱们以前配置的是否单独编译的开关,咱们须要修改以下2个地方:

图1-4功能模块配置单独编译开关

能够看到咱们要修改的就是我红框框住的地方,当咱们的开关打开的时候,咱们就把他当成一个单独的application来编译,而且赋予它一个独一无二的applicationId,这样咱们就能够经过刚刚在gradle.properties中配置的开关来控制它是否单独做为一个application来编译。

而对于咱们的入口module--app模块咱们则须要作以下的配置:
图1-5主module的gradle配置

咱们除了须要配置基本的ARouter以及commonlib依赖之外还须要在app模块的gradle文件中根据开关选择是否须要依赖咱们的功能模块,这个和各个功能模块中的配置是相呼应的。

而对于其余组件模块,重复上述步骤便可完成组件化框架的搭建:
图1-6项目结构图

####在完成了组件化框架的搭建后咱们来简单的看看框架中一些具备特点的使用方法。

######咱们首先来看一下各个模块的页面间是怎样跳转的。

咱们以前已经依赖了ARouter(详细用法参照https://github.com/alibaba/ARouter),咱们要用它来帮咱们实现跳转须要如下几步:
图2-1

跳转的方法就如同图2-1中显示,咱们须要标明目标页面,附带上要传送的参数,而后调用navigation()就能够跳转了,不过有人问目标页面怎么看着就是一个路径,它是怎样定义的?
图2-2目标页面的配置

  • 首先要用@Route注解标注页面,并在path变量中给页面定义一个路径
  • 对于传送过来的变量咱们直接定义一个同名的字段用@Autowired变量标注,Arouter会对该字段自动赋值
  • 最后咱们还须要将该页面注入到ARouter中(原理相似ButterKnife),让他帮咱们完成咱们须要的工做

这样,咱们就完成了页面间的跳转了,是否是比起咱们传统的方法更加简单合理?

####最后咱们来看一下组件间如何为彼此提供服务。

  • 这里我想在主module中调用home组件的sayHello方法来Toast一我的的名字
  • 那home里的方法怎样才能被其余模块(包括主模块和其余组件模块)调用

图3-1公共接口的定义

首先在commonlib模块里建立一个暴露方法的接口,并定义接口签名,同时继承 Iprovider 接口

而后在home模块中继承commonlib里定义的接口,并实现签名方法。

图3-2在提供方法的module中的配置

这里咱们一样使用Arouter的 @Router注解来提供此次服务的路由。

最后,咱们在其余模块使用 @Autowired 注解就能够调用该方法了

图3-3对于方法的调用

能够看到咱们一样使用了@Autowired注解来初始定baseService服务,并将页面注入Arouter中便可调用服务中的方法,且对于服务的依赖是基于接口的依赖,大大提升了其灵活性!

####基本组件化框架的搭建就完成了,但愿认真看完的朋友能有所收获!若有不正之处还望指正!

以上项目的码云地(欢迎参与改进):
https://gitee.com/zsq519/ARouterBaseProject

相关文章
相关标签/搜索