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制作的产品广告效果
Dec 08 Javascript
JavaScript 布尔操作符解析  && || !
Aug 10 Javascript
jQuery中$.each使用详解
Jan 29 Javascript
js实现星星打分效果的方法
Jul 05 Javascript
javascript判断数组内是否重复的方法
Apr 21 Javascript
全面解析Bootstrap中form、navbar的使用方法
May 30 Javascript
JavaScript中的普通函数和箭头函数的区别和用法详解
Mar 21 Javascript
JS 调试中常见的报错问题解决方法
May 20 Javascript
vue.js内置组件之keep-alive组件使用
Jul 10 Javascript
vue异步axios获取的数据渲染到页面的方法
Aug 09 Javascript
关于自定义Egg.js的请求级别日志详解
Dec 12 Javascript
react使用CSS实现react动画功能示例
May 18 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使用cookie实现记住用户名和密码实现代码
2015/04/27 PHP
Symfony2 session用法实例分析
2016/02/04 PHP
PHP+Jquery与ajax相结合实现下拉淡出瀑布流效果【无需插件】
2016/05/06 PHP
Laravel中间件实现原理详解
2016/10/09 PHP
PHP 表单提交及处理表单数据详解及实例
2016/12/27 PHP
php格式文件打开的四种方法
2018/02/24 PHP
laravel框架实现敏感词汇过滤功能示例
2020/02/15 PHP
PHP页面静态化――纯静态与伪静态用法详解
2020/06/05 PHP
Javascript 学习书 推荐
2009/06/13 Javascript
jQuery Dialog 弹出层对话框插件
2010/08/09 Javascript
javascript中"/"运算符常见错误
2010/10/13 Javascript
Jquery数独游戏解析(一)-页面布局
2010/11/05 Javascript
js父窗口关闭时子窗口随之关闭完美解决方案
2014/04/29 Javascript
JavaScript、tab切换完整版(自动切换、鼠标移入停止、移开运行)
2016/01/05 Javascript
JavaScript的字符串方法汇总
2016/07/31 Javascript
基于Vue.js实现数字拼图游戏
2016/08/02 Javascript
通过BootStrap-select插件 js jQuery控制select属性变化
2017/01/03 Javascript
Kotlin学习第一步 kotlin语法特性
2017/05/25 Javascript
JS去掉字符串末尾的标点符号及删除最后一个字符的方法
2017/10/24 Javascript
Bootstrap 树控件使用经验分享(图文解说)
2017/11/06 Javascript
Es6 Generator函数详细解析
2018/02/24 Javascript
JQuery选中select组件被选中的值方法
2018/03/08 jQuery
vue使用v-if v-show页面闪烁,div闪现的解决方法
2018/10/12 Javascript
Vue+Typescript中在Vue上挂载axios使用时报错问题
2019/08/07 Javascript
javascript实现扫雷简易版
2020/08/18 Javascript
Python中的rjust()方法使用详解
2015/05/19 Python
神经网络python源码分享
2017/12/15 Python
python并发编程之线程实例解析
2017/12/27 Python
Python实现合并同一个文件夹下所有PDF文件的方法示例
2018/04/28 Python
Python调用.NET库的方法步骤
2019/12/27 Python
python 使用while循环输出*组成的菱形实例
2020/04/12 Python
详解python with 上下文管理器
2020/09/02 Python
手把手教你从PyCharm安装到激活(最新激活码),亲测有效可激活至2089年
2020/11/25 Python
html5指南-7.geolocation结合google maps开发一个小的应用
2013/01/07 HTML / CSS
公司领导班子召开党的群众路线教育实践活动总结大会新闻稿
2014/10/21 职场文书
小程序实现文字循环滚动动画
2021/06/14 Javascript