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中使用Echarts可视化库的完整步骤记录
Nov 18 Vue.js
VUE+Element实现增删改查的示例源码
Nov 23 Vue.js
vue + el-form 实现的多层循环表单验证
Nov 25 Vue.js
详解Vue3 Teleport 的实践及原理
Dec 02 Vue.js
vue3.0+vue-router+element-plus初实践
Dec 02 Vue.js
Vue 简单实现前端权限控制的示例
Dec 25 Vue.js
如何使用vue3打造一个物料库
May 08 Vue.js
vue Element-ui表格实现树形结构表格
Jun 07 Vue.js
使用Vue3+Vant组件实现App搜索历史记录功能(示例代码)
Jun 09 Vue.js
vue选项卡切换的实现案例
Apr 11 Vue.js
vue elementUI表格控制对应列
Apr 13 Vue.js
vue实现在data里引入相对路径
Jun 05 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类
2008/04/09 PHP
创建数据库php代码 用PHP写出自己的BLOG系统
2010/04/12 PHP
php基础学习之变量的使用
2011/06/09 PHP
php实现的ping端口函数实例
2014/11/12 PHP
ucenter通信原理分析
2015/01/09 PHP
php中array_multisort对多维数组排序的方法
2020/06/21 PHP
浅析Yii2 GridView 日期格式化并实现日期可搜索教程
2016/04/22 PHP
jQuery $.each的用法说明
2010/03/22 Javascript
jquery获取焦点和失去焦点事件代码
2013/04/21 Javascript
js replace替换所有匹配的字符串
2014/02/13 Javascript
javascript中scrollTop详解
2015/04/13 Javascript
Js制作点击输入框时默认文字消失的效果
2015/09/05 Javascript
Bootstrap实现水平排列的表单
2016/07/04 Javascript
jquery html5 视频播放控制代码
2016/11/06 Javascript
Angular组件化管理实现方法分析
2017/03/17 Javascript
Vue.js tab实现选项卡切换
2017/05/16 Javascript
javascript中mouseenter与mouseover的异同
2017/06/06 Javascript
vue-cli webpack 引入jquery的方法
2018/01/10 jQuery
小程序登录之支付宝授权的实现示例
2019/12/13 Javascript
bootstrap实现嵌套模态框的实例代码
2020/01/10 Javascript
[55:16]Mski vs VGJ.S Supermajor小组赛C组 BO3 第二场 6.3
2018/06/04 DOTA
python对配置文件.ini进行增删改查操作的方法示例
2017/07/28 Python
python爬虫之xpath的基本使用详解
2018/04/18 Python
python给微信好友定时推送消息的示例
2019/02/20 Python
使用pickle存储数据dump 和 load实例讲解
2019/12/30 Python
中国领先的汽车保养服务平台:途虎养车
2019/10/18 全球购物
大学生求职中的自我评价
2013/10/01 职场文书
社区端午节活动方案
2014/01/28 职场文书
装修设计师求职信
2014/02/26 职场文书
纺织工程专业推荐信
2014/09/08 职场文书
学前班幼儿评语大全
2014/12/29 职场文书
先进事迹材料怎么写
2014/12/30 职场文书
2015年转正工作总结范文
2015/04/02 职场文书
担保公司2015年终工作总结
2015/10/14 职场文书
解除租赁合同协议书
2016/03/21 职场文书
解决Navicat for MySQL 连接 MySQL 报2005错误的问题
2021/05/29 MySQL