• Vue3 使用 Event Bus


    本文已整理到 Github,地址 👉 blog

    如果我的内容帮助到了您,欢迎点个 Star 🎉🎉🎉 鼓励鼓励 :) ~~

    我希望我的内容可以帮助你。现在我专注于前端领域,但我也将分享我在有限的时间内看到和感受到的东西。


    在 Vue2 中,创建 Event Bus 如下:

    export const bus = new Vue()
    1. bus.$on(...)
    2. bus.$emit(...)

    在 Vue3 中,Vue 不再是构造函数,而是 Vue.createApp({}) 返回一个没有 $on$emit$once 方法的对象。

    根据官方文档 Vue 3 迁移指南所建议的,我们可以使用 mitttiny-emitter 库在组件之间调度事件。

    这里我们使用 mitt,它的源码也很简单,👉 地址

    安装

    pnpm i mitt

    您也可以单独把代码拷贝一份到项目,代码量较少。

    用法

    与 Vue2 一样,封装为 myBus.js

    1. import mitt from 'mitt'
    2. export default mitt()

    或者,你也可以定义为全局变量:

    1. import { createApp } from 'vue'
    2. import App from './App.vue'
    3. import mitt from 'mitt'
    4. const app = createApp(App)
    5. app.config.globalProperties.emitter = mitt()

    然后,封装一个 hooks:

    1. // src/hooks/useEmitter.js
    2. import { getCurrentInstance } from 'vue'
    3. export default function useEmitter() {
    4. const internalInstance = getCurrentInstance()
    5. const emitter = internalInstance.appContext.config.globalProperties.emitter
    6. return emitter
    7. }

    当然,为了方便管理,你也可以在需要用到的地方单独引入 mitt。

    示例

    假设我们有一个 sidebarheader,其中包含一个关闭/打开侧栏的按钮,我们需要该按钮来切换侧边栏组件内的某些属性。

    点击按钮发出 toggle-sidebar 带有一些 payload 的事件:

    1. <template>
    2. <button @click="toggleSidebar">toggle</button>
    3. </template>
    4. <script setup>
    5. import { ref } from 'vue'
    6. import useEmitter from '@/hooks/useEmitter'
    7. const sidebarOpen = ref(true)
    8. const emitter = useEmitter()
    9. const toggleSidebar = () => {
    10. sidebarOpen.value = !sidebarOpen.value
    11. emitter.emit('toggle-sidebar', sidebarOpen.value)
    12. }
    13. </script>

    在侧边栏中接收带有 payload 的事件:

    1. <template>
    2. <aside class="sidebar" :class="{'sidebar--toggled': !isOpen}">
    3. {{ isOpen }}
    4. </aside>
    5. </template>
    6. <script setup>
    7. import { ref, onMounted } from 'vue'
    8. import useEmitter from '@/hooks/useEmitter'
    9. const isOpen = ref(true)
    10. const emitter = useEmitter()
    11. onMounted(() => {
    12. emitter.on('toggle-sidebar', (isOpen) => {
    13. isOpen.value = isOpen
    14. })
    15. })
    16. </script>

    更多资料

    实现一个 Event Bus

  • 相关阅读:
    【监督学习之决策树和随机森林】
    2020江西省赛A 莫比乌斯反演
    微信公众号怎么从个人转为企业?
    全网没有之一的API 文档:Swagger
    B. Paranoid String
    leetcode 557. Reverse Words in a String III(字符串中单词逆序III)
    mEngine.hasImplicitBatchDimension
    Linux namespace技术应用实践--调用宿主机命令(tcpdump/ip/ps/top)检查docker容器网络、进程状态
    python爬虫之selenium库,浏览器访问搜索页面并提取信息,及隐藏浏览器运行
    git 中如何删除 Untracked files 文件
  • 原文地址:https://blog.csdn.net/weixin_46267040/article/details/125468354