关于在vue中使用eventBus接收监听被多次触发的解决办法

先看这个bug
创建一个eventBus:

import Vue from "vue";
export default new Vue;

兄弟组件分别导入eventBus:

import eventBus from "eventBus";

传值:
这里我把传值直接放在了列表更新函数里面进行触发了

fetchList () {
      userList(this.listQuery).then((res) => {
        this.tableData = res.data.data;
        eventBus.$emit('sendByBus', res.data.data)
        this.pageQuery.p = res.data.page
      });
    },

接收值:
同时更新界面数据

eventBus.$on("sendByBus", (data) => {
      this.person = data;
      data.map((item, index) => {
        this.allmodelType.push(item.id)
      })
      this.fetchList()
    });

问题来了:
当刷新完界面第一次点击tabs
在这里插入图片描述
这还挺正常(它本身走一次smList,兄弟走一次userList然后又触发一次smList)
当我点击切换组件的时候 离谱的来了
第二次点击:
在这里插入图片描述
第三次点击:
在这里插入图片描述
它会一直累加进行请求 除非你再次刷新界面 它才会从新从1开始再累加 这肯定不行的
为什么会有这个问题呢???
首先事件总线是全局的 也就是说 当你每次emit触发一次这条线就已经创建存在了 当整个程序在运行时他就会一直存在 每当你触发一次就会新建一条事件总线 也是为什么会触发多次函数的问题所在
如何解决???
既然能创建肯定就能销毁,每次使用后把他销毁不久完了 就像计时器每次使用完都会有其相应的clear
组件销毁前销毁当前事件总线:

beforeDestroy(){
    eventBus.$off("sendByBus",)
  },
};
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值