组件通讯包括:父子组件间的通信和兄弟组件间的通信。在组件化系统构建中,组件间通信必不可少的 (vuex以后再说)。

父组件--> 子组件

1. 属性设置

父组件关键代码如下:

1 <template>
2     <Child :child-msg="msg"></Child>
3 </template>

子组件关键代码如下:

1 export default {
2   name: 'child',
3   props: {
4     child-msg: String
5   }
6 };

child-msg 为父组件给子组件设置的额外属性值,属性值需在子组件中设置props,子组件中可直接使用child-msg变量。

2. 子组件调用父组件

子组件通过 $parent 获得父组件,通过 $root 获得最上层的组件。

子组件--> 父组件

1. 发送事件/监听事件

子组件中某函数内发送事件:

this.$emit('toparentevent', 'data');

父组件监听事件:

<Child @toparentevent="toparentevent"></Child>
// 在methods里接收
methods: {toparentevent(msg) {// msg就是传递的数据
     console.log(msg) }
}        

toparentevent 为子组件自定义发送事件名称,父组件中@toparentevent为监听事件,toparentevent为父组件处理方法。

2. 父组件直接获取子组件属性或方法

给要调用的子组件起个名字。将名字设置为子组件 ref 属性的值。

<!-- 子组件。 ref的值是组件引用的名称 -->
<child-component ref="aName"></child-component>

父组件中通过 $refs.组件名 来获得子组件,也就可以调用子组件的属性和方法了。

// 获取child.属性
this.$refs.aName.child
// 调用child.方法()
this.$refs.aName.child()

父组件通过 $children 可以获得所有直接子组件(父组件的子组件的子组件不是直接子组件)。需要注意 $children 并不保证顺序,也不是响应式的。

eventBus中央通信

各组件可自己定义好组件内接收外部组件的消息事件即可,不用理会是哪个组件发过来;而对于发送事件的组件,亦不用理会这个事件到底怎么发送给我需要发送的组件。

先设 main.js 置Bus

// main.js中
new Vue({el: '#app',router,template: '<App/>',components: { App },data: {eventBus: new Vue()}})

组件内监听事件:

1 created() {
2     this.$root.eventBus.$on('childa-message', function(data) {
3       console.log(data);
4     });
5   }

发送事件的组件:

this.$root.eventBus.$emit('childa-message', this.data)

可能存在如下问题:
1.第一次触发的时候页面中的on事件没有被触发
2. 为什么后面再一次依次去触发的时候会出现,每一次都会发现好像之前的on事件分发都没有被撤销一样,导致每一次的事件触发执行越来越多

解答:

1. 当我们还在页面A的时候,页面B还没生成,也就是页面B中的 created中所监听的来自于A中的事件还没有被触发。这个时候当你A中emit事件的时候,B其实是没有监听到的,

当你从页面A到页面B跳转的时候,发生了什么?首先是先B组件先created然后beforeMount接着A组件才被销毁,A组件才执行beforeDestory,以及destoryed

所以,我们可以把A页面组件中的emit事件写在beforeDestory中去。因为这个时候,B页面组件已经被created了,也就是我们写的$on事件已经触发了

修改如下:在beforeDestory生命周期里,$emit事件

1 beforeDestroy () {
2  this.$root.eventBus.$emit('child-message',this.data)
3  }

2.  因为B页面$on事件是不会自动清楚销毁的,需要我们手动来销毁,所以我在B组件页面中添加Bus.$off来关闭,销毁后就不存在执行多次的情况了   。代码如下: 

1 // 在B组件页面中添加以下语句,在组件beforeDestory的时候销毁。
2   beforeDestroy () {
3     this.root.eventBus.$off('child-message')4   },

总结: 所以,要用eventBus 来进行页面组件之间的数据传递,需要注意亮点,组件A$emit事件应在beforeDestory生命周期内。其次,组件B内的$on记得要销毁。

转载于:https://www.cnblogs.com/ljx20180807/p/9778782.html

vue组件通信v兄弟组件通信eventbus遇到的问题(多次触发、第一次不触发)相关推荐

  1. vue组件间通信之兄弟组件通信(vue3.0$EventBus)

    vue组件间通信之兄弟组件通信(vue3.0$EventBus) vue组件中的数据传递最最常见的就是父子组件之间的传递.父传子通过props向下传递数据给子组件:子传父通过$emit发送事件,并携带 ...

  2. React创建组件的方法,组件的props属性、state属性的用法和特点,父子组件传值,兄弟组件传值

    创建组件的方法,组件的props属性.state属性的用法和特点,父子组件传值,兄弟组件传值 1.react组件 1.1.创建组件的方法 1.1.1.函数组件 定义一个组件最简单的方式是使用JavaS ...

  3. 实现非父子之间通信,兄弟组件之间的数据传递--eventBus

    vue中,组件传值的方法常见的也就那几种, 1.父组件向子组件传值,用props 属性, 2.子组件主要通过事件传递数据给父组件子向父传数据可以用$emit触发传,但是这种方法无法实现兄弟组件直接传数 ...

  4. vue父子组件通信,兄弟组件通信

    目录 一.父子组件通信 1.子组件通过 props 获取父组件变量和父组件调用子组件中的方法(这两个都是父传子的思想) a:子组件通过 props 获取父组件变量 b:父组件调用子组件中的方法 2.父 ...

  5. Linux——(管道练习)C实现父子进程通信、兄弟进程通信、多个读写端操作管道及管道缓冲区大小、fifo实现非血缘间进程通信

    一. 父子进程通信 lswc-l 父进程ls写到管道,子进程wc管道的内容 父进程创建管道(拥有读写两端),父进程fork子进程,父进程要将原本输出到屏幕上的内容输出到管道中,用dup实现,然后exe ...

  6. vue组件化通信之兄弟组件传值

    vue组件化通信之父向子传值 vue组件化通信之子向父传值 在vue中兄弟节点传值一般有两种方法:$parent和 $root, 建议使用前者 使用$parent **parent.vue** < ...

  7. vue从入门到精通之进阶篇(二)组件通信:兄弟组件通信

    $emit和$on进行组件之间的传值 注意:emit和emit和emit和on的事件必须在一个公共的实例上,才能够触发 需求: ​ 1.有A,B,C三个组件,同时挂载到入口组件中 ​ 2.将A组件中的 ...

  8. vue2.0s中eventBus实现兄弟组件通信

    在vue1.0中,组件之间的通信主要通过vm.$dispatch沿着父链向上传播和用vm.$broadcast向下广播来实现.然而在vue2.0中,已经废除了这种用法. vuex加入后,对组件之间的通 ...

  9. vue的$emit 与$on父子组件与兄弟组件的之间通信

    本文主要对vue 用$emit 与 $on 来进行组件之间的数据传输. 主要的传输方式有三种: 1.父组件到子组件通信 2.子组件到父组件的通信 3.兄弟组件之间的通信 一.父组件传值给子组件 父组件 ...

最新文章

  1. lua判断字符不为空或空格_Lua判断Table是否为空的方法(空的table即{})
  2. 使用RFECV、递归特征消除 (Recursive Feature Elimination)进行特征筛选详解及实战
  3. Unity 消息发送机制 解析
  4. 为何说“内容+社交”是奥运发展化趋势?
  5. python爬虫能干啥-Python爬虫还能干什么?
  6. Linux设备模型(热插拔、mdev 与 firmware)
  7. UML建模工具EA和Rose比较
  8. 【LeetCode从零单排】No19.RemoveNthNodeFromEndofList
  9. CVPR 2019 开源论文 | 基于翻译向量的图像翻译
  10. python脚本批量生成数据
  11. Python机器学习Numpy, Scipy, Pandas, Scikit-learn, Matplotlib, Keras, NN速查手册
  12. SLES修改本地FTP安装源
  13. 漫画:什么是字典序算法
  14. 【linux】图解Linux最常用命令!秒懂!
  15. CABasicAnimation animationWithKeyPath Types
  16. 设备管理系统未来发展的四大趋势
  17. vs2008的永久破解安装
  18. 我的世界服务器物品管理,我的世界NEI物品管理器mod详细图文使用教程
  19. vue项目保存页面为pdf 、word
  20. 阿铭Linux_网站维护学习笔记20190416

热门文章

  1. HTML <dfn> 标签的简单介绍
  2. 辗转相除法求多项式的最大公因式
  3. [攻防世界 pwn]——Mary_Morton
  4. shell tr 替换 空格_shell tr命令
  5. 北京化工大学计算机科专业,北京化工大学专业介绍及排名 哪些专业最好
  6. linux查看上次重启日志和ip,Linux實時查看日志,訪問前10IP 和相關命令
  7. vlookup查找值不唯一时怎么办
  8. XSLT简单教程--XSLT的实例
  9. Eclipse插件安装的三种方式
  10. Tomcat 6 数据源配置