利用ARouter实现组件间通信,解决子模块调用主模块问题

2019-06-13 11:32:33

传送门 利用ARouter实现组件间通信,解决子模块调用主模块问题

一年之前我写过一篇组件间通信的博客Android模块间通信(不使用三方库),当时用的是反射,自己去维护一套“对应关系”(分别给每个模块命名,分别给每个类命名帮助反射找到对应的类),我的这种映射关系就是属于强映射(必须人力注明),阿里巴巴的ARouter就通过注解的方式实现了软映射(你只需要把两个需要对应的类加上注解,其他的维护不用你麻烦)


如果你还没使用过ARouter请你按照这篇下面博客尝试使用下然后再往下看组件通信的内容(不然的话可能会懵逼)Android Studio接入ARouter以及简单使用


如果你使用过ARouter请继续往下看:


1 子模块定义一个与主模块通信的接口 ISkill继承自IProvider

2 主模块定义一个ISkill实现类ISkillImpl

3 子模块通过ARouter+反射去获取这个ISkillImpl的实例化对象

4 通过3的实例化对象进行通信


理论是无聊的,接下来让我们看代码


1 子模块中定义一个与主模块通信的接口 ISkill继承自IProvider


public interface ISkill extends IProvider {

    public void eat();

}

1

2

3

2 主模块定义一个ISkill实现类ISkillImpl,注意加上注解!!


@Route(path = "/app/ISkillImpl")

public class ISkillImpl implements ISkill {


    @Override

    public void eat() {

        Log.i("TAG", "大王叫我来巡山!");

    }


    @Override

    public void init(Context context) {


    }

}

1

2

3

4

5

6

7

8

9

10

11

12

13

3,4 子模块通过ARouter获取这个ISkillImpl的实例化对象


  ISkill impl=ARouter.getInstance().build("/app/ISkillImpl").navigation();

  impl.eat();


  • 2020-05-20 22:29:05

    javascript中为何在匿名function函数后面还外加

    它可以解释成为“匿名函数自调用”,也就是说,定义一个匿名函数,然后马上调用它(因为它是匿名的,如果不立即调用就获取不到该函数的引用了)。通常它被应用在一些大型的JS框架中(如上面所说的),因为这个匿名函数的函数体相当于提供一个匿名的名字空间,这样就不会再与用户自定义的JS函数、变量、对象发生冲突了。尽管JS没有显示地提供命名空间的定义和使用机制,但这种匿名方式却不失为是一种很好的解决命名空间问题的方法。

  • 2020-05-20 22:30:14

    js中利用prototype给类添加方法

    你可能会想,这不就是个简单的函数声明?没错,这个函数就是一个类的定义的实现。如何使用这个类呢?看下面的代码:var cls1 = new MyClass(); 这样,利用new就可以生成MyClass的一个实例了。所以在js中可以说函数就是类,类就是函数。

  • 2020-05-21 10:56:53

    fixed z-index失效

    作为一个假的前端,在调试一个页面时出现了如下bug。 左侧的菜单固定为fixed时,二级菜单无法设置有效的z-index,导致菜单隐藏在页面元素之下,明明页面元素的z-index是1,但是无论把菜单的z-index设置为多大,都不管用。

  • 2020-05-24 08:10:18

    echarts标题(title)配置

    show:true,//显示策略,默认值true,可选为:true(显示) | false(隐藏) text: '主标题',//主标题文本,'\n'指定换行 link:'',//主标题文本超链接,默认值true target: null,//指定窗口打开主标题超链接,支持'self' | 'blank',不指定等同为'blank'(新窗口) subtext: '副标题',//副标题文本,'\n'指定换行 sublink: '',//副标题文本超链接