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 相关文章推荐
[对联广告] JS脚本类
Aug 27 Javascript
教你如何解密js/vbs/vbscript加密的编码异处理小结
Jun 25 Javascript
jQuery中hasClass()方法用法实例
Jan 06 Javascript
jQuery插件multiScroll实现全屏鼠标滚动切换页面特效
Apr 12 Javascript
JQuery select(下拉框)操作方法汇总
Apr 15 Javascript
jquery使整个div区域可以点击的方法
Jun 24 Javascript
关于JS中setTimeout()无法调用带参函数问题的解决方法
Jun 21 Javascript
jQuery实现frame之间互通的方法
Jun 26 jQuery
JS+canvas绘制的动态机械表动画效果
Sep 12 Javascript
JS实现调用本地摄像头功能示例
May 18 Javascript
在Vue中获取组件声明时的name属性方法
Sep 12 Javascript
JS Array.from()将伪数组转换成数组的方法示例
Mar 23 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
收音机史话 - 1960年代前后的DIY
2021/03/02 无线电
Apache2 httpd.conf 中文版
2006/11/17 PHP
PHP实现手机归属地查询API接口实现代码
2012/08/27 PHP
PHP之生成GIF动画的实现方法
2013/06/07 PHP
怎样使用php与jquery设置和读取cookies
2013/08/08 PHP
php生成唯一的订单函数分享
2015/02/02 PHP
php验证码实现代码(3种)
2015/09/07 PHP
php实现微信分享朋友链接功能
2019/02/18 PHP
PHP随机数函数rand()与mt_rand()的讲解
2019/03/25 PHP
如何运行/调试你的PHP代码
2020/10/23 PHP
克隆javascript对象的三个方法小结
2011/01/12 Javascript
ASP.NET jQuery 实例1(在TextBox里面创建一个默认提示)
2012/01/13 Javascript
JavaScript中神奇的call()方法
2015/03/12 Javascript
jQuery取消ajax请求的方法
2015/06/09 Javascript
Bootstrap modal 多弹窗之叠加引起的滚动条遮罩阴影问题
2017/02/27 Javascript
JS实现下拉菜单列表与登录注册弹窗效果
2017/08/10 Javascript
Next.js实现react服务器端渲染的方法示例
2019/01/06 Javascript
Vue项目路由刷新的实现代码
2019/04/17 Javascript
深入剖析JavaScript instanceof 运算符
2019/06/14 Javascript
Vue 实现前端权限控制的示例代码
2019/07/09 Javascript
浅析Vue 中的 render 函数
2020/02/28 Javascript
python模拟登录百度贴吧(百度贴吧登录)实例
2013/12/18 Python
zbar解码二维码和条形码示例
2014/02/07 Python
python 自动重连wifi windows的方法
2018/12/18 Python
阿里云ECS服务器部署django的方法
2019/08/29 Python
使用HTML5技术开发一个属于自己的超酷颜色选择器
2013/09/22 HTML / CSS
教你使用Canvas处理图片的方法
2017/11/28 HTML / CSS
蹦床仓库:Trampoline Warehouse
2018/12/06 全球购物
OLEDBConnection和SQLConnection有什么区别
2013/05/31 面试题
学校岗位设置方案
2014/01/16 职场文书
大专毕业自我鉴定
2014/02/04 职场文书
车辆转让协议书
2014/04/15 职场文书
2014迎国庆演讲稿
2014/09/19 职场文书
村主任个人对照检查材料
2014/10/01 职场文书
2015秋季开学演讲稿范文
2015/07/16 职场文书
Python连接Postgres/Mysql/Mongo数据库基本操作大全
2021/06/29 Python