IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue任意组件间通信:全局事件总线bus -> 正文阅读

[JavaScript知识库]vue任意组件间通信:全局事件总线bus

Vue组件间的通信

父 => 子,子 => 父,都可以通过简单的props实现传参,兄弟组件间以及其他任意组件间的通信除了使用vuex、storage,还可以使用全局事件总线。

全局事件总线

全局事件总线,相当于一个中间人,任何组件间想要实现通信,都可以通过全局事件总线,一般定义为$bus。作为数据的接收者组件,只要在$bus身上绑定自定义事件,并将回调函数留在接收者组件自身;在数据的提供者组件中通过触发绑定在$bus上的自定义事件,同时携带参数,就可以实现两个组件间的通信

注册全局事件总线

前提条件

  1. 保证所有组件都能看得见,即所有组件都能调用到这个全局事件总线
  2. 能够调用$on、$emit、、$off 方法

注册

main.js 文件

new Vue({
	beforeCreated(){
		// 在Vue的原型对象上注册全局事件总线 $bus,保证所有组件都能够调用到
		// $bus是Vue实例对象
		Vue.prototype.$bus = this
	}
})

使用

  1. 接收数据
    在接收数据的组件中给 $bus 绑定事件
// 一般在页面挂载完成以后绑定事件
mounted(){
	/*
	* 事件回调函数必须为箭头函数 --- this的指向问题
	* 箭头函数是没有自己的this,向外找this是mounted的this,
	* Vue中的所有生命周期钩子函数的this都是当前组件实例对象
	*/
	this.$bus.$on('自定义事件名', 事件回调函数(接收的数据) => {
		...
	})
}
  1. 提供数据
// 通过用户操作或者某个生命周期钩子函数触发自定义事件
this.$bus.$emit('自定义事件名', 要传递的数据)

注意事项

最好在beforeDestroy生命周期钩子中,用 $off 解绑当前组件所用到的自定义事件。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-30 18:14:48  更:2022-03-30 18:16:41 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:19:21-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码