Vue全局事件总线你了解吗


Posted in Vue.js onFebruary 24, 2022

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

看下面具体的例子。

父组件:App

<template>
    <div class="app">
        <Company/>
        <Employee/>
    </div>
</template>

<script>
import Company from "./components/Company.vue";
import Employee from "./components/Employee.vue";

export default {
    components:{
        Company,
        Employee
    }
}
</script>

<style>
.app{
    background: gray;
    padding: 5px;
}
.btn{
    margin-left:10px;
    line-height: 30px;
    background: ivory;
    border-radius: 5px;
}
</style>

子组件:Company和Employee

<template>
  <div class="company">
      <h2>公司名称:{{name}}</h2>
      <h2>公司地址:{{address}}</h2>
      <button @click="sendMessage">点我发送</button>
  </div>
</template>

<script>
export default {
    name:"Company",
    data(){
        return {
            name:"五哈技术有限公司",
            address:"上海宝山"
        }
    },
    methods:{
        sendMessage(){
            console.log("Company组件发送数据:",this.name);
            this.$bus.$emit("demo",this.name);
        }
    }

}    
</script>

<style scoped>
.company{
    background: orange;
    background-clip: content-box;
    padding: 10px;
}
</style>
<template>
  <div class="employee">
      <h2>员工姓名:{{name}}</h2>
      <h2>员工年龄:{{age}}</h2>
  </div>
</template>

<script>
export default {
    name:"Employee",
    data(){
        return {
            name:"张三",
            age:25
        }
    },
    mounted(){
        this.$bus.$on("demo",(data) => {
            console.log("Employee组件监听demo,接收数据:",data);
        })
    },
    beforeDestroy() {
        this.$bus.$off("demo");
    }
}

</script>

<style scoped>
.employee{
    background: skyblue;
    background-clip: content-box;
    padding: 10px;
}
</style>

入口文件: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全局事件总线你了解吗

Vue全局事件总线你了解吗

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注三水点靠木的更多内容!   

Vue.js 相关文章推荐
Vue实现手机号、验证码登录(60s禁用倒计时)
Dec 19 Vue.js
antdesign-vue结合sortablejs实现两个table相互拖拽排序功能
Jan 08 Vue.js
vue+echarts实现中国地图流动效果(步骤详解)
Jan 27 Vue.js
vue 动态添加的路由页面刷新时失效的原因及解决方案
Feb 26 Vue.js
vue3.0中使用element的完整步骤
Mar 04 Vue.js
vue中三级导航的菜单权限控制
Mar 31 Vue.js
Vue3中toRef与toRefs的区别
Mar 24 Vue.js
vue如何使用模拟的json数据查看效果
Mar 31 Vue.js
Vue组件更新数据v-model不生效的解决
Apr 02 Vue.js
Vue OpenLayer 为地图绘制风场效果
Apr 24 Vue.js
vue.js 使用原生js实现轮播图
Apr 26 Vue.js
Vue的生命周期一起来看看
Vue的过滤器你真了解吗
Feb 24 #Vue.js
Vue监视数据的原理详解
Feb 24 #Vue.js
Vue的列表之渲染,排序,过滤详解
Vue3如何理解ref toRef和toRefs的区别
Feb 18 #Vue.js
Vue h函数的使用详解
Feb 18 #Vue.js
详解Vue中$props、$attrs和$listeners的使用方法
Feb 18 #Vue.js
You might like
如何在PHP中使用Oracle数据库(4)
2006/10/09 PHP
基于session_unset与session_destroy的区别详解
2013/06/03 PHP
Yii实现多数据库主从读写分离的方法
2014/12/29 PHP
PHP基于Closure类创建匿名函数的方法详解
2017/08/17 PHP
(JS实现)MapBar中坐标的加密和解密的脚本
2007/05/16 Javascript
js中格式化日期时间型数据函数代码
2010/11/08 Javascript
jQuery的初始化与对象构建之浅析
2011/04/12 Javascript
Javascript合并表格中具有相同内容单元格示例
2013/08/11 Javascript
js自动查找select下拉的菜单并选择(示例代码)
2014/02/26 Javascript
nodejs中实现路由功能
2014/12/29 NodeJs
javascript中sort()的用法实例分析
2015/01/30 Javascript
JavaScript中的关联数组问题
2015/03/04 Javascript
Javascript aop(面向切面编程)之around(环绕)分析
2015/05/01 Javascript
使用javascript提交form表单方法汇总
2015/06/25 Javascript
基于jquery实现放大镜效果
2015/08/17 Javascript
js创建jsonArray传输至后台及后台全面解析
2016/04/11 Javascript
Easyui的组合框的取值与赋值
2016/10/28 Javascript
完美解决node.js中使用https请求报CERT_UNTRUSTED的问题
2017/01/08 Javascript
angular directive的简单使用总结
2017/05/24 Javascript
使用JS和canvas实现gif动图的停止和播放代码
2017/09/01 Javascript
基于layui内置模块(element常用元素的操作)
2019/09/20 Javascript
layui table单元格事件修改值的方法
2019/09/24 Javascript
python实现简单socket程序在两台电脑之间传输消息的方法
2015/03/13 Python
python操作excel的包(openpyxl、xlsxwriter)
2018/06/11 Python
python实现定时提取实时日志程序
2018/06/22 Python
python time.sleep()是睡眠线程还是进程
2019/07/09 Python
python利用itertools生成密码字典并多线程撞库破解rar密码
2019/08/12 Python
Python第三方包之DingDingBot钉钉机器人
2020/04/09 Python
python调用有道智云API实现文件批量翻译
2020/10/10 Python
Tom Dixon官网:英国照明及家具设计和制造公司
2019/03/01 全球购物
Dr. Martens马汀博士澳大利亚官网:马丁靴鼻祖
2019/07/02 全球购物
餐饮管理自我介绍信
2014/01/15 职场文书
禁毒宣传活动总结
2014/08/26 职场文书
大学本科生职业生涯规划书范文
2014/09/14 职场文书
群众路线四风问题整改措施
2014/09/27 职场文书
入党后的感想
2015/08/10 职场文书