Navigation框架自定义路由库强行组件化的可行性分析

答案:

不可以

文章前提:

  • 熟悉并理解阿里巴巴ARouter框架源码
  • 熟悉Navigation框架组件化(官网的方式)

如果你不熟悉,我建议看两个文章:

官网navigation多模块化,(官方的组件化只能在主模块使用deeplink使用fragment)

后面我会出一篇路由库的解析,并奉上源码地址。

开始:

官网的多模块方式我就不讲了,只能在主模块引用,相当于没有用。

我们需要知道几个问题的答案:

这里我们将阿里的ARouter作为路由库的例子:

1. 我们为什么需要路由库?

很简单,我们想要在业务模块a里引用业务模块b的activity,但是我们不能让模块a直接依赖模块b,因为这样是违反组件化原则的,因此我们需要通过别的方式拿到这个activity。

简单说一下原则:

  1. 解耦和模块化:业务模块之间的相互依赖会增加耦合性,使得模块之间的关系变得复杂。如果一个模块发生变化,可能会影响到其他模块,导致代码难以维护和理解。通过减少模块之间的依赖,可以更好地实现解耦和模块化,使得各个模块更加独立和可重用。

  2. 可维护性和可扩展性:业务模块之间的相互依赖会增加代码的复杂性,降低代码的可维护性和可扩展性。当一个模块依赖于其他模块时,它就会受制于其他模块的变化,从而增加了维护的难度。通过减少模块之间的依赖,可以降低代码的复杂性,提高代码的可维护性和可扩展性。

  3. 灵活性和可测试性:业务模块之间的相互依赖会影响代码的灵活性和可测试性。如果一个模块依赖于其他模块,那么在测试时就需要同时考虑这些依赖关系,增加了测试的复杂性。通过减少模块之间的依赖,可以提高代码的灵活性和可测试性,使得代码更容易编写和测试。

2.我们可以通过什么方式拿到这个activity ...?

少说有五种: 

  • eventbus
    太乱了。
  • 广播
    难以管理
  • 类加载模式:直接使用活动的全类名字:

    维护起来太麻烦,修改一个文件夹,就要在所有引用过的地方修改
  • 使用隐式意图的方式:
    在activity中定义意图过滤器,需要这个意图唯一,如果活动多了,就不好管理了。
  • 使用全局Map的方式:
    这个网上有,应该是比较简单的,在common里定义个baseApplication,然后定义application的代理接口,用一下反射应该就好了。把这个Map放在common里面。
    缺点:注册的活动多了,就不好了

注意这个全局Map的思想!

我们如果可以在全局持有所有activity的全类名,再结合第三种方法(类加载模式),不就可以随意跳转了吗?

对,这就是ARouter的核心思想!

3.ARouter的实现原理:

通过注解处理器,对有我们自定义注解的activity,生成类,

这个类的执行的就是map的put方法!红色框框圈出来的是一个接口,在使用反射的时候,我们的生成类肯定是不一样的,所以在调用的时候就要强转成同一个类型,就是IRootGroup

在app启动的时候,通过反射调用put方法,把所有的路径都放在一个map里面管理起来。

你想要启动哪一个activity的时候,就会通过类加载模式进行跳转,也就是startActivity()

结合navigation框架

为什么我说navigatin框架不可以?

因为在navigation框架中,即使你已经拥有了想要跳转graph的id,但是这个id必须出现在调用这个方法的模块的graph文件里面,并且配合action,但是我们是多模块化,所以没办法引用这个action,不然我们不就直接可以调用了吗?

有一位大哥给navigation框架写了个Router,但是在那个版本的navigation是可以的,现在好像不行了。。。我不太确定

这是那位大哥的项目地址

各位大哥要是有了思路,欢迎在下方评论。

  • 17
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值