Vue学习计划-Vue2--VueCLi(五)全局事件总线、消息订阅与发布(pubsub)

抛出问题:我们多级组件,或者任意不想关的子组件如何传递数据呢?

1. 全局事件总线($bus

  1. 一种组件间通信的方式,适用于任意组件间通信

  2. 全局事件总线示意图:
    在这里插入图片描述

  3. 安装全局事件总线:

new Vue({
    ....
    beforeCreate(){
        Vue.prototype.$bus = this // 安装全局事件总线,$bus就相当于vm
    }
})
  1. 使用事件总线:
    1. 接收数据:A组件想接收数据,则在A组件中给$bus绑定自定义事件,事件的回调留在A组件自身
    methods: {
        demo(data){.....}
    },
    mounted(){
        this.$bus.$on('xxx', this.demo)
    }
    
    1. 提供数据: this.$bus.$emit('xxx', 数据)
  2. 最好在beforeDestroy钩子中,用$off去解绑当前组件所用到的事件

示例:我们继续使用Vue学习计划-Vue2–VueCLi(四)组件传值和自定义事件示例中的4个组件:父组件APP.vue,子组件SelectInput.vueSelectList .vueSelectMulDel.vue,我们这里只更拿App.vueSelectInput.vue为例
1. 在main.js中安装全局事件总线:

2. 子组件SelectInput.vue内提供数据:
在这里插入图片描述
3. 父组件App.vue内给$bus绑定事件,并在beforeDestroy中销毁绑定事件:
在这里插入图片描述

2. 消息订阅与发布(pubsub

  1. 一种组件间通信的方式,适用于任意组件间通信
  2. 使用步骤:
    1. 安装pubsub: npm i pubsub-js或者yarn add pubsub-js或者cnpm i pubsub-js
    2. 引入: import PubSub from 'pubsub-js'
    3. 接收数据: A组件想接收数据,则在A组件中订阅消息,订阅的回调留在A组件自身
    methods: {
        demo(data){.....}
    },
    mounted(){
        this.pid = PubSub.subscribe('xxx', this.demo) // 订阅消息
    }
    
    1. 提供数据: PubSub.publish('xxx', 数据)
    2. 最好在beforeDestroy钩子中,用PubSub.unsubscribe(pid)去取消订阅

示例:拿$busApp.vueSelectInput.vue为:

  1. 安装依赖;不需要main.js内写任何内容,但是需要在用到订阅发布的依赖组件内手动引入

  2. 修改SelectInput.vue组件:
    在这里插入图片描述

  3. 修改App.vue组件:
    在这里插入图片描述

  4. 总结一下:其实不管是全局事件总线还是消息订阅与发布,我们都可以看出来,其实本质都是一样的:将自定义事件和数据存到一个公共的空间内,谁用谁去调。

最近更新

  1. TCP协议是安全的吗?

    2023-12-15 07:00:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-15 07:00:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-15 07:00:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-15 07:00:02       20 阅读

热门阅读

  1. Linux下实现Word文件转PDF

    2023-12-15 07:00:02       42 阅读
  2. HTTPS 请求中的证书验证详解(Python版)

    2023-12-15 07:00:02       42 阅读
  3. 策略模式学习

    2023-12-15 07:00:02       38 阅读
  4. uniApp常见知识点-问题&答案

    2023-12-15 07:00:02       30 阅读
  5. Zabbix“专家坐诊”第215期问答汇总

    2023-12-15 07:00:02       37 阅读
  6. WebSocket 协议的原理和实践

    2023-12-15 07:00:02       42 阅读
  7. Springboot+uniapp 做H5端的授权登录

    2023-12-15 07:00:02       26 阅读
  8. Vue中 v-show 和 v-if 有什么区别

    2023-12-15 07:00:02       26 阅读
  9. 量子计算对密码学的威胁及应对方式

    2023-12-15 07:00:02       50 阅读
  10. 浅谈NLP和大模型的关系

    2023-12-15 07:00:02       42 阅读
  11. [论文笔记] 大模型主流Benchmark测试集介绍

    2023-12-15 07:00:02       40 阅读