Vue组件通信中非父子组件传值知识点总结


Posted in Javascript onDecember 05, 2019

前言:

如果想要了解非父子关系的组件传值,最好是在了解父传子和子传父的基础上在来了解非父子传值可能会有更透彻的思路。

因为非父子传值是通过定义事件总线来代理实现父传子+子传父从而实现的传值方式。

这是我总结的父子传值相关的知识,可供参考:  https://3water.com/article/121806.htm

然后大概回顾一下父子传值的过程:

Vue组件通信中非父子组件传值知识点总结

根据上述信息可知,如果两个组件需要传递值那么需要这两个组件之间是父子关系才能传递数据。

那么如果有这样一个组件,既可以帮你传递数据,又可以帮你接收数据该多好啊?

于是乎,一个叫事件总线的概念出现了,它就可以帮助实现你想要的这些功能。

了解事件总线之前,需要先看下两个重要的方法。

前置知识: 

1. $emit(event, data)方法

event: 触发的事件类型

data: 触发这个事件时传递的参数

2. $on(event, callBack(data))方法

event: 绑定的事件类型

callBack: 绑定的这个事件所对应的回调函数,其默认的第一个参数data是使用$emit触发这个事件时所传递的参数

在了解了这两个方法后,再来看下面的这张图:

Vue组件通信中非父子组件传值知识点总结

如果还是不太明白,那就转换成代码在分析一下:

首先,定义一个eventBus: 

// eventBus.js 
// 事件总线: 只需要导出一个Vue实例即可
import Vue from 'vue'
export default new Vue()

然后,在A组件中导入eventBus, 并触发自定义的AtoB事件

// A.vue// 导入eventBus
import eventBus from "./eventBus"

// 触发事件并传递参数
eventBus.$emit("AtoB", "Data_A")

最后,在B组件中导入eventBus,并监听自定义的AtoB事件

// B.vue// 导入eventBus
import eventBus from "./eventBus"

// 触发事件并传递参数
eventBus.$on("AtoB", data =>{
  console.log(data); // "Data_A" 
})

总结:

要想了解非父子传值必先了解父子间的传值非父子传值的核心在于通过事件总线作为一个中介然后通过在“传递值”的组件中触发事件总线的某个自定义的事件来传递一个值(如果是多个值,可以传递一个对象) 最后在“接收值”的组件中来监听事件总线中你触发的那个自定义事件来接收数据

以上就是本次介绍的全部相关知识点,感谢大家的学习和对三水点靠木的支持。

Javascript 相关文章推荐
jquery中prop()方法和attr()方法的区别浅析
Sep 06 Javascript
js实现的下拉框二级联动效果
Apr 30 Javascript
浅谈jQuery绑定事件会叠加的解决方法和心得总结
Oct 26 Javascript
微信公众号  提示:Unauthorized API function 问题解决方法
Dec 05 Javascript
jQuery自定义多选下拉框效果
Jun 19 jQuery
使用vue-infinite-scroll实现无限滚动效果
Jun 22 Javascript
JS中实现隐藏部分姓名或者电话号码的代码
Jul 17 Javascript
VUE2.0+ElementUI2.0表格el-table循环动态列渲染的写法详解
Nov 30 Javascript
详解小程序毫秒级倒计时(适用于拼团秒杀功能)
May 05 Javascript
jquery中attr、prop、data区别与用法分析
Sep 25 jQuery
解决echarts vue数据更新,视图不更新问题(echarts嵌在vue弹框中)
Jul 20 Javascript
请求时token过期自动刷新token操作
Sep 11 Javascript
基于javascript实现贪吃蛇经典小游戏
Apr 10 #Javascript
微信小程序登录时如何获取input框中的内容
Dec 04 #Javascript
微信小程序日历插件代码实例
Dec 04 #Javascript
微信小程序request请求封装,验签代码实例
Dec 04 #Javascript
vue中使用极验验证码的方法(附demo)
Dec 04 #Javascript
基于vue-cli3创建libs库的实现方法
Dec 04 #Javascript
使用vue-cli4.0快速搭建一个项目的方法步骤
Dec 04 #Javascript
You might like
PHP脚本数据库功能详解(中)
2006/10/09 PHP
简单采集了yahoo的一些数据
2007/02/14 PHP
PHP 抓取新浪读书频道的小说并生成txt电子书的代码
2009/12/18 PHP
php从数组中随机抽取一些元素的代码
2012/11/05 PHP
php从字符串创建函数的方法
2015/03/16 PHP
Linux系统下php获得系统分区信息的方法
2015/03/30 PHP
通过PHP简单实例介绍文件上传
2015/12/16 PHP
详解WordPress中创建和添加过滤器的相关PHP函数
2015/12/29 PHP
PHP实现二维数组按照指定的字段进行排序算法示例
2019/04/23 PHP
firefox中JS读取XML文件
2006/12/21 Javascript
Javascript 兼容firefox的一些问题
2009/05/21 Javascript
给artDialog 5.02 增加ajax get功能详细介绍
2012/11/13 Javascript
使用js在页面中绘制表格核心代码
2013/09/16 Javascript
js采用map取到id集合组并且实现点击一行选中一行
2013/12/16 Javascript
jQuery取消ajax请求的方法
2015/06/09 Javascript
jQuery 移动端artEditor富文本编辑器
2016/01/11 Javascript
Bootstrap进度条学习使用
2017/02/09 Javascript
Node.js 使用流实现读写同步边读边写功能
2017/09/11 Javascript
javascript input输入框模糊提示功能的实现
2017/09/25 Javascript
详解webpack的proxyTable无效的解决方案
2018/06/15 Javascript
关于element-ui表单中限制输入纯数字的解决方式
2020/09/08 Javascript
构建Python包的五个简单准则简介
2015/06/15 Python
python实现按键精灵找色点击功能教程,使用pywin32和Pillow库
2020/06/04 Python
Python 列表推导式需要注意的地方
2020/10/23 Python
python热力图实现简单方法
2021/01/29 Python
jupyter 添加不同内核的操作
2021/02/06 Python
CSS3中的content属性使用示例
2015/07/20 HTML / CSS
销售代表求职自荐信
2013/10/01 职场文书
上课迟到检讨书100字
2014/01/11 职场文书
道路交通安全实施方案
2014/03/12 职场文书
教师对学生的评语
2014/04/28 职场文书
邀请函怎么写
2015/01/30 职场文书
大明湖导游词
2015/02/03 职场文书
地道战观后感2000字
2015/06/04 职场文书
2016年共产党员公开承诺书
2016/03/24 职场文书
python 爬取豆瓣网页的示例
2021/04/13 Python