利用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();


  • 2017-01-19 00:45:56

    nodejs之process进程

    虽然node对操作系统做了很多抽象的工作,但是你还是可以直接和他交互,比如和系统中已经存在的进程进行交互,创建工作子进程。node是一个用于事件循环的线程,但是你可以在这个事件循环之外创建其他的进程(线程)参与工作。

  • 2017-01-19 01:05:32

    process对象

    process对象是Node的一个全局对象,提供当前Node进程的信息。它可以在脚本的任意位置使用,不必通过require命令加载。该对象部署了EventEmitter接口。

  • 2017-01-20 21:59:11

    WEBPACK DEV SERVER

    webpack-dev-server是一个小型的node.js Express服务器,它使用webpack-dev-middleware中间件来为通过webpack打包生成的资源文件提供Web服务。它还有一个通过Socket.IO连接着webpack-dev-server服务器的小型运行时程序。

  • 2017-01-21 10:32:29

    Vue-cli proxyTable 解决开发环境的跨域问题

    和后端联调时总是会面对恼人的跨域问题,最近基于Vue开发项目时也遇到了这个问题,两边各自想了一堆办法,查了一堆资料,加了一堆参数,最后还得我把自己的localhost映射成上线时将要使用的域名。

  • 2017-01-21 21:44:29

    详解 ESLint 规则,规范你的代码

    在很久之前就想通过工具来规范自己的代码风格,减少程序出错的概率,如果看过我的 一个前端程序猿的Sublime Text3的自我修养 ,这篇博客的朋友,肯定知道在当时我使用 SublimeLinter-jshint 插件来规范风格,但是实际上一直懒癌发作也没去看它的文档,使用着它默认的规则。不过现在是时候切换到 ESLint 了!

  • 2017-01-23 23:09:16

    使用 CSS3 实现超炫的 Loading(加载)动画效果

     SpinKit 是一套网页动画效果,包含8种基于 CSS3 实现的很炫的加载动画。借助 CSS3 Animation 的强大功能来创建平滑,易于定制的动画。SpinKit 的目标不是提供一个每个浏览器都兼容的解决方案,而是给现代浏览器提供更优的技术实现方案和更佳的使用体验。(为保证最佳的效果,请在 Chrome、Firefox 和 Safari 等现代浏览器中浏览)