利用ARouter实现组件间通信,解决子模块调用主模块问题
2023-09-27 14:21:17 时间
如果你还没使用过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(); }
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) { } }
3 子模块通过ARouter获取这个ISkillImpl的实例化对象
ISkill impl=ARouter.getInstance().build("/app/ISkillImpl").navigation(); impl.eat();
相关文章
- 从一个组件的实现来深刻理解JS中的继承
- vue写组件时的命名规范
- vue.js父组件访问子组件
- React非父子组件之间的事件传递
- 集群通信组件Tribes之怎样维护集群成员信息
- Android 短信模块分析(二) MMS中四大组件核心功能详解
- Bootstrap组件之响应式导航条
- XMLmind XSL-FO Converter开发组件
- 【Android 组件化】路由组件 ( 路由框架概述 )
- vue实现简单表格组件
- 2.QT-窗口组件(QWidget),QT坐标系统,初探消息处理(信号与槽)
- Vue全局组件开发,Vue.use(xxx)一次引入,全局使用 【Vue 非父子组件通信】
- Vue.js 中,7种定义组件模板的方法
- 关于React-native里Android原生模块和组件的写法
- React-native设置全局函数globle【适用于有组件嵌套时】
- 负载均衡组件Ribbon核心-@LoadBalanced-上