• vue兄弟组件传值$on多次执行的问题


    前端vue项目中,各个组件(非父子关系也可)之间可以通过Bus进行事件通信。

    组件间通过如下:

    this.$Bus.$on("事件名", 回调函数);
    

    来监听总线Bus中的某个事件,执行回调函数。

    问题描述:

    有时候会发生事件只被emit触发了一次,但是回调函数却被多次执行的现象。这种现象往往发生在页面跳转退出后重新进入的时候。

    产生原因:

    this.$Bus.$on实际是向Bus容器中添加一个事件监听器,当页面跳转时,原来的vue组件被注销,但是原来vue组件向Bus容器中添加的事件监听器并不会被移除。因此,当下次进入这个vue组件对应的页面时,执行到this.$Bus.$on时,又会向Bus容器中添加一个重复的事件监听器,以此类推,导致Bus容器中有很多个一模一样的事件监听器,从而导致事件只被触发一次,但是回调函数被执行多次的现象。

    解决方案:

    在vue的beforeDetory钩子函数中将本vue组件往Bus容器中添加的时间监听器全部手动移除。

    beforeDestroy () {
    	this.$bus.$off('事件名');
    },
    
  • 相关阅读:
    Splay 区间操作(二)
    P1351 联合权值
    Splay 区间操作
    P1801 黑匣子_NOI导刊2010提高(06)
    P3620 [APIO/CTSC 2007]数据备份
    T25990 [Wind Festival]Running In The Sky
    P1484 种树
    P4177 [CEOI2008]order
    题解 P2762 【太空飞行计划问题】
    dalao&话
  • 原文地址:https://www.cnblogs.com/actorhuang/p/15006181.html
Copyright © 2020-2023  润新知