解决vue bus.$emit触发第一次$on监听不到问题


Posted in Javascript onJuly 28, 2020

$emit与emit与emit与 $on的用法

新建bus.js

import Vue from 'vue'

export const bus = new Vue()

引用bus.js

import {bus} from './bus'

bus.$on('test', function (msg) {
 console.log(msg)
})
 
bus.$emit('test', 11)

bus.$emit触发第一次emit触发第一次emit触发第一次 $on监听不到

因为$emit 先于 $on 执行了,VUE并没有储存监听事件,所以无法监听到数据。

我这里遇到的是在调用$emit的时候子组件并没有创建,所以无法监听到数据,子组件创建之后,便可以监听到传递过来的数据

我的解决方法是在调用$emit的时候使用emit的时候使用emit的时候使用 $nextTick()方法

用法:将回调延迟到下次 DOM 更新循环之后执行。在修改数据之后立即使用它,然后等待 DOM 更新。它跟全局方法 Vue.nextTick 一样,不同的是回调的 this 自动绑定到调用它的实例上。

new Vue({
 // ...
 methods: {
 // ...
 example: function () {
  // DOM 还没有更新
  this.$nextTick(function () {
  // DOM 现在更新了
  bus.$emit('test', 11)
  })
 }
 }
})

避免路由跳转多个组件重复监听,只需要在路由跳转之前移除当前组件监听事件即可:

beforeDestroy () {
 // 销毁监听事件
 this.$bus.$off('test')
 }

补充知识:组件之间使用this.$bus.$on传值之前需要先this.$bus.$off注销事件

this.$bus是全局变量

a、b是两个父组件,c是子组件。

c页面触发事件:

this.$bus.$emit(event)

a、b页面监听c组件的事件

pagea:

this.$bus.$on(event, () => {
 this.status = 'reserve'
})

pageb:

this.$bus.$on(event, () => {
  this.status = 'buying'
})

如果在调用了a页面之后,再调用b页面,回导致this.status是reserve而不是我们想要的buying。

正确写法:

pagea:

this.$bus.$off(event).$on(event, () => {
 this.status = 'reserve'
})

pageb:

this.$bus.$off(event).$on(event, () => {
  this.status = 'buying'
})

以上这篇解决vue bus.$emit触发第一次$on监听不到问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
一直复略了的一个问题,关于表单重复提交
Feb 15 Javascript
innertext , insertadjacentelement , insertadjacenthtml , insertadjacenttext 等区别
Jun 29 Javascript
ExtJS 2.0实用简明教程 之Border区域布局
Apr 29 Javascript
JavaScript获取表格(table)当前行的值、删除行、增加行
Jul 03 Javascript
jQuery+html5+css3实现圆角无刷新表单带输入验证功能代码
Aug 21 Javascript
jQuery实现浮动层随浏览器滚动条滚动的方法
Sep 22 Javascript
jQuery3.0中的buildFragment私有函数详解
Aug 16 Javascript
微信小程序button组件使用详解
Jan 31 Javascript
微信小程序实现多选功能
Nov 04 Javascript
JavaScript之解构赋值的理解
Jan 30 Javascript
mpvue+vant app搭建微信小程序的方法步骤
Feb 11 Javascript
基于原生JS封装的Modal对话框插件的示例代码
Sep 09 Javascript
vue+element-ui JYAdmin后台管理系统模板解析
Jul 28 #Javascript
vue实现虚拟列表功能的代码
Jul 28 #Javascript
vue.js 解决v-model让select默认选中不生效的问题
Jul 28 #Javascript
Vue2.0 $set()的正确使用详解
Jul 28 #Javascript
JavaScript 监听组合按键思路及代码实现
Jul 28 #Javascript
JavaScript动画实例之粒子文本的实现方法详解
Jul 28 #Javascript
Vue $emit()不能触发父组件方法的原因及解决
Jul 28 #Javascript
You might like
在PHP中使用与Perl兼容的正则表达式
2006/11/26 PHP
Yii中创建自己的Widget实例
2016/01/05 PHP
浅谈PHP SHA1withRSA加密生成签名及验签
2019/03/18 PHP
jQuery $.get 的妙用 访问本地文本文件
2012/07/12 Javascript
JQuery调webservice实现邮箱验证(检测是否可用)
2013/05/21 Javascript
js弹出div并显示遮罩层
2014/02/12 Javascript
js数组方法扩展实现数组统计函数
2014/04/09 Javascript
利用JavaScript的AngularJS库制作电子名片的方法
2015/06/18 Javascript
JavaScript中字符串(string)转json的2种方法
2015/06/25 Javascript
你有必要知道的25个JavaScript面试题
2015/12/29 Javascript
JavaScript快速切换繁体中文和简体中文的方法及网站支持简繁体切换的绝招
2016/03/07 Javascript
Bootstrap时间选择器datetimepicker和daterangepicker使用实例解析
2016/09/17 Javascript
浅谈JS中String()与 .toString()的区别
2016/10/20 Javascript
js 转义字符及URI编码详解
2017/02/28 Javascript
Vue computed计算属性的使用方法
2017/07/14 Javascript
jQuery Ajax向服务端传递数组参数值的实例代码
2017/09/03 jQuery
AnglarJs中的上拉加载实现代码
2018/02/08 Javascript
JavaScript实现刮刮乐效果
2020/11/01 Javascript
[01:42]TI4西雅图DOTA2前线报道 第一顿早饭哦
2014/07/08 DOTA
python连接mysql并提交mysql事务示例
2014/03/05 Python
Python中的各种装饰器详解
2015/04/11 Python
简单理解Python中基于生成器的状态机
2015/04/13 Python
可能是最全面的 Python 字符串拼接总结【收藏】
2018/07/09 Python
Python将一个Excel拆分为多个Excel
2018/11/07 Python
Python安装与卸载流程详细步骤(图解)
2020/02/20 Python
使用pytorch实现论文中的unet网络
2020/06/24 Python
python实现网页录音效果
2020/10/26 Python
床上用品全球在线购物:BeddingInn
2016/12/18 全球购物
亚马逊墨西哥站:Amazon.com.mx
2018/08/26 全球购物
大学毕业生自我鉴定
2013/11/05 职场文书
精通CAD能手自荐书
2014/01/31 职场文书
计算机大学生职业生涯规划书范文
2014/02/19 职场文书
2014年两会学习心得范例
2014/03/17 职场文书
2014教育局对照检查材料思想汇报
2014/09/23 职场文书
2015年复活节活动总结
2015/02/27 职场文书
与死神共舞观后感
2015/06/15 职场文书