• vue 兄弟组件间传值(bus方式)的坑(重复触发和首次未触发)


    场景:组件A header    组件B  页面

    点击组件A,引起组件B表格数据的查询

    代码实现

     1 //标签
     2 <el-badge :value="examineNum" :max="99" class="item">
     3       <el-button @click="examineBtn()" size="small">未审核订单</el-button>
     4 </el-badge>
     5 
     6 
     7 // A组件触发事件
     8 examineBtn() {
     9   this.$router.push({
    10     path: '/orderA',
    11     query: {
    12       dataType: 'allNoAudit'
    13     }
    14   });
    15   MsgBus.$emit('allNoAudit', this.clickNum++); //每次都让值改变,保证每次点击都会被接收
    16 }
    17 
    18 //B组件接收
    19 MsgBus.$on('allNoAudit', (e) => {
    20   this.allNoAuditBOl = e;
       console.log('resize');
    21 this.resizeTable(); 22 });
     

    问题:

    在点击未审核按钮时,

    1.本页面点击,只会触发一次

    2.当涉及到页面切换时,先在管理页面,点击‘未审核’按钮进入审核页面。重复几次,会发现会多次打印'resize',具体是,每切换一次页面,点击按钮的时候,就会多打印一次

    对应上面情况。1是正常的,是我们想要的结果,2就是坑了

    为什么会出现这种情况呢?按照上述情况,我的猜想是每次组件挂载后,点击‘未审核按钮’使用$emit都会建立的一个新的消息机制,而组件销毁时这个消息机制一直未被销毁。不停的切换页面,会不断的挂载和销毁组件,如果每切换一次页面就点一次按钮,就会创建一个新的消息机制,不断的创建而不销毁,导致B组件接受事件里的操作重复触发,控制台重复多次打印resize

    解决办法:

    上面的逻辑想通了,解决的办法就很简单,在每次页面销毁前,去销毁这个消息机制。

    MsgBus.$off();

    铛铛铛铛,重复解决了。

    至于首次未触发,主要还是页面未创建的时候,按钮已经发出了消息,页面当然接收不到了,方法看代码~我就不赘述了。。。

    加油,everyone

     1 //标签
     2  <el-badge :value="examineNum" :max="99" class="item">
     3        <el-button @click="examineBtn()" size="small">未审核订单</el-button>
     4  </el-badge>
     5  
     6  
     7  // A组件触发事件
     8  examineBtn() {
     9    this.$router.push({
    10      path: '/orderA',
    11      query: {
    12        dataType: 'allNoAudit'
    13      }
    14    });
    15    //如果在订单管理页面,发出消息的时候未审核页面还未被创建完成,无法接受消息就不会执行
    16   //这的东西主要是对钩子函数的理解,想了解朋友以后可以来看看,下次更新
    17    setTimeout(()=>{                                        
    18            MsgBus.$emit('allNoAudit', this.clickNum++);  //每次都让值改变,保证每次点击都会被接收
    19    },200)        
    20  }
    21  
    22  //B组件接收
    23  beforeCreate() {                            //为了尽快收到消息,写在钩子函数最开始
    24      MsgBus.$on('allNoAudit', (e) => {
    25        this.allNoAuditBOl = e;  console.log('resize');
    26        this.resizeTable();
    27      });
    28  },
        beforeDestroy() {
          MsgBus.$off();
        }
      
  • 相关阅读:
    带结点与不带结点用头插法和尾插法创建单链表
    高中数学教资面试记录
    学习爬虫——test1——模拟浏览器去访问网站
    解决centos虚拟机中使用virt-manager创建虚拟机遇到的镜像导入问题
    pycharm更改背景颜色
    控制函数调用的流程
    简单的获取list的下标
    种一棵树的时间,不是以前,也不是未来的某一天,而是现在。
    将八位教师随机分配到三个办公室——python
    使用tomcat部署idea项目方法(1)
  • 原文地址:https://www.cnblogs.com/hanchongyang/p/8669983.html
Copyright © 2020-2023  润新知