千家信息网

Vue全局事件总线是什么

发表于:2024-10-25 作者:千家信息网编辑
千家信息网最后更新 2024年10月25日,这篇文章主要为大家展示了"Vue全局事件总线是什么",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"Vue全局事件总线是什么"这篇文章吧。全局事件总线,是组件
千家信息网最后更新 2024年10月25日Vue全局事件总线是什么

这篇文章主要为大家展示了"Vue全局事件总线是什么",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"Vue全局事件总线是什么"这篇文章吧。

全局事件总线,是组件间的一种通信方式,适用于任何组件间通信。

看下面具体的例子。

父组件:App

子组件:Company和Employee

入口文件:main.js

import Vue from 'vue';  import App from './App.vue';Vue.config.productionTip = false;new Vue({  el:"#app",  render: h => h(App),  beforeCreate(){     Vue.prototype.$bus = this;  }})

父组件App,子组件CompanyEmployee

子组件Company和Employee之间通过全局数据总线进行数据传递。

在main.js中,定义了全局事件总线:$bus

$bus定义在Vue.prototype,因此$bus对所有组件可见,即所有组件可通过this.$bus访问。

$bus被赋值为this,即vm实例,因此$bus拥有vm实例上的所有属性和方法,如$emit$on$off等。

new Vue({  beforeCreate(){     Vue.prototype.$bus = this;  }})

使用全局事件总线

$bus.$on,监听事件。Employee组件中定义了监听事件,监听demo事件;

$bus.$emit,触发事件。Company组件中定义了触发事件,点击按钮执行sendMessage回调,该回调将触发demo事件。

以上是"Vue全局事件总线是什么"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

0