美文网首页
vue事件总线EventBus

vue事件总线EventBus

作者: 湘兰沅芷 | 来源:发表于2021-07-19 23:07 被阅读0次

vue组件有父子组件通信:props
兄弟组件通信:
可以使用vuex,还可以使用事件总线eventBus

使用方法:
1.初始化:
// event-bus.js
import Vue from 'vue'
export const EventBus = new Vue()

另外一种方式,可以直接在项目中的 main.js 初始化 EventBus :
// main.js
Vue.prototype.$EventBus = new Vue()

2.发送事件
import { EventBus } from "../event-bus.js";
export default {
methods: {
sendMsg() {
EventBus.emit("aMsg", '来自A页面的消息'); } } }; </script> 3.接收事件 EventBus.on("aMsg", (msg) => {
// A发送来的消息
this.msg = msg;
});

EventBus如果使用不善,EventBus会是一种灾难,到底是什么样的“灾难”了?大家都知道vue是单页应用,如果你在某一个页面刷新了之后,与之相关的EventBus会被移除,这样就导致业务走不下去。还要就是如果业务有反复操作的页面,EventBus在监听的时候就会触发很多次,也是一个非常大的隐患。这时候我们就需要好好处理EventBus在项目中的关系。通常会用到,在vue页面销毁时,同时移除EventBus事件监听。
4.移除监听
import {
eventBus
} from './event-bus.js'
EventBus.$off('aMsg', {})

全局EventBus

var EventBus = new Vue();
Object.defineProperties(Vue.prototype, {
$bus: {
get: function () {
return EventBus
}
}
})

在这个特定的总线中使用两个方法on和emit。一个用于创建发出的事件,它就是emit;另一个用于订阅on:

var EventBus = new Vue();

this.bus.emit('nameOfEvent', { ... pass some event data ...});

this.bus.on('nameOfEvent',(event) => { // ... }) 然后我们可以在某个Vue页面使用this.bus.$emit("sendMsg", '我是web秀');,另一个Vue页面使用

this.bus.on('updateMessage', function(value) {
console.log(value); // 我是web秀
})
同时也可以使用this.bus.off('sendMsg')来移除事件监听。

相关文章

  • Vue的事件总线

    事件总线是什么? EventBus 又称为事件总线。在Vue中可以使用 EventBus 来作为沟通桥梁的概念,就...

  • vue 事件总线EventBus的概念、使用

    两个组件之间毫无关系,用到 vue 中的事件总线 EventBus的概念来传递数据 EventBus又称事件总线,...

  • EventBus

    EventBus的简介 EventBus 又称为事件总线。在Vue中可以使用 EventBus 来作为沟通桥梁的概...

  • Vue事件总线(EventBus)

    阐述一下 VUE中 eventbus 的原理 解答:EventBus是消息传递的一种方式,基于一个消息中心,订阅和...

  • vue事件总线EventBus

    vue组件有父子组件通信:props兄弟组件通信:可以使用vuex,还可以使用事件总线eventBus 使用方法:...

  • Vue事件总线(EventBus)

    vue组件非常常见的有父子组件通信,兄弟组件通信。而父子组件通信就很简单,父组件会通过props向下传数据给子组件...

  • [Android组件解读] EventBus3.0解析

    记得前段时间讲解过otto事件总线的概念,但是大家习惯用的事件总线应该还是EventBus。 EventBus介绍...

  • eventBus源码解析

    EventBus定义:是一个发布 / 订阅的事件总线。 发布者,订阅者,事件,总线。 EventBus,可以说,就...

  • vue2.x+element-ui项目常遇到的问题

    1.清除定时器2.Vue事件总线(eventBus)$on()会多次触发3.vue 在table中增/删/改/查,...

  • EventBus和RxBus的使用

    EventBus介绍: Rx:函数响应式编程,EventBus:事件总线 。EventBus 功能类似handle...

网友评论

      本文标题:vue事件总线EventBus

      本文链接:https://www.haomeiwen.com/subject/ybcleltx.html