EventBus3.1.1使用

EventBus,使用简单,功能强大,集成简单,跨进程通信高度解耦,真是牛逼啊。
使用步骤:
1,集成:
compile 'org.greenrobot:eventbus:3.1.1'
2,注册,想在哪个页面接受信息,就在哪个页面注册:
比如在MainActivity中的onCreate()方法中

 EventBus.getDefault().register(this);//注册Eventbus

注意不要忘记在onDestroy中释放:

 if(EventBus.getDefault().isRegistered(this)) {
            EventBus.getDefault().unregister(this);
        }

3,写接受的方法:

    @Subscribe(threadMode = ThreadMode.MAIN)
    public void Event(MessageEvent messageEvent){
        Toast.makeText(BaseActivity.this,messageEvent.getMessage(),Toast.LENGTH_LONG).show();
    }

注意上面的注解必须写,这是3.0之后的改变。还有根据实际需求选择线程模式也是必须的。
EventBus3.0有四种线程模型,分别是:

POSTING (默认) 表示事件处理函数的线程跟发布事件的线程在同一个线程。
MAIN 表示事件处理函数的线程在主线程(UI)线程,因此在这里不能进行耗时操作。
BACKGROUND 表示事件处理函数的线程在后台线程,因此不能进行UI操作。如果发布事件的线程是主线程(UI线程),那么事件处理函数将会开启一个后台线程,如果果发布事件的线程是在后台线程,那么事件处理函数就使用该线程。
ASYNC 表示无论事件发布的线程是哪一个,事件处理函数始终会新建一个子线程运行,同样不能进行UI操作。

4,在需要发送信息的页面一行发送消息:

EventBus.getDefault().post(new MessageEvent("发送的数据"));
MessageEvent.class:
public class MessageEvent {
    private String message;
    public MessageEvent(String message){
        this.message=message;
    }
    public String getMessage(){
        return message;
    }
    public void setMessage(String message){
        this.message=message;
    }
}

就是这么简单,记录开发过程的点滴,让我们一天天变的强大起来。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Vue 中,你可以使用事件总线(Event Bus)来实现组件之间的通信。事件总线是一个空的 Vue 实例,可以用于触发和监听自定义事件。 首先,在你的项目中创建一个新的 Vue 实例作为事件总线: ```javascript // eventBus.js import Vue from 'vue'; export const eventBus = new Vue(); ``` 然后,在需要通信的组件中,你可以使用事件总线来触发事件或监听事件: ```javascript // ComponentA.vue import { eventBus } from './eventBus.js'; export default { methods: { sendMessage() { eventBus.$emit('message', 'Hello from Component A!'); } } } ``` ```javascript // ComponentB.vue import { eventBus } from './eventBus.js'; export default { data() { return { receivedMessage: '' }; }, mounted() { eventBus.$on('message', (message) => { this.receivedMessage = message; }); } } ``` 在上面的示例中,ComponentA 在方法中通过 `eventBus.$emit` 触发了名为 `message` 的自定义事件,并传递了消息内容。而 ComponentB 在 `mounted` 钩子函数中通过 `eventBus.$on` 监听了 `message` 事件,当事件触发时会执行回调函数并将消息内容赋值给 `receivedMessage`。 这样,ComponentA 和 ComponentB 之间就可以通过事件总线进行通信了。请确保在不需要通信时及时销毁事件监听,以避免内存泄漏。 注意:事件总线在组件之间是全局共享的,可以用于任意组件之间的通信。但是如果你的项目越来越复杂,建议考虑使用更好的状态管理方案,如 Vuex。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值