Vue3实战笔记(54)—揭秘Vue3实战:1分钟学会mitt,轻松玩转跨组件通讯

本文主要是介绍Vue3实战笔记(54)—揭秘Vue3实战:1分钟学会mitt,轻松玩转跨组件通讯,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、自定义的 useMitt
  • 二、在组件中使用 useMitt:
  • 三、确保 useMitt 的单例性
  • 总结


前言

在 Vue3 中,由于官方移除了on\off 和 $once 实例方法,导致原先基于 Vue2 的事件总线(EventBus)模式不再适用。因此,对于需要进行组件间通信的场景,Vue3 推荐使用如 props、emits、provide/inject、vuex、pinia 等官方提供的方案。然而在某些情况下,开发者可能仍希望利用事件总线的简单性,特别是在小型项目中。这时,Mitt.js 就成为了一个推荐的选项,它提供了与框架无关、简洁且高效的事件监听和触发机制。


一、自定义的 useMitt

Mitt.js 是一个轻量级的第三方事件发射器库,专为 Vue3 和其他框架设计。

在 Vue 3 中使用 mitt 或类似的库时,我们通常会创建一个自定义的 useMitt Composition API 函数,以便在组件内部使用 mitt 的功能。这样,我们就可以利用 Vue 3 的 Composition API 来更好地组织和复用逻辑。

首先,创建一个 useMitt.js 文件,并在其中定义一个 useMitt 函数,用于返回 mitt 实例的方法。


// useMitt.js  
import mitt from 'mitt';  // 创建一个 mitt 实例,并导出相关的函数  
const emitter = mitt();  export function useMitt() {  return {  emit: emitter.emit.bind(emitter),  on: emitter.on.bind(emitter),  off: emitter.off.bind(emitter),  // 可以根据需要添加其他 mitt 方法  };  
}

二、在组件中使用 useMitt:

现在,你可以在任何需要通信的组件中导入并使用 useMitt 函数。每个组件都将使用相同的 mitt 实例来发射和监听事件。

代码如下(示例):

// ChildComponent.vue  
<template>  <button @click="emitEvent">Emit Event</button>  
</template>  <script>  
import { ref } from 'vue';  
import { useMitt } from './useMitt';  export default {  setup() {  const { emit } = useMitt();  const message = ref('Hello from ChildComponent!');  const emitEvent = () => {  emit('child-event', message.value);  };  return {  emitEvent,  };  },  
};  
</script>
// ParentComponent.vue  
<template>  <div>  <ChildComponent />  <p v-if="receivedMessage">Received: {{ receivedMessage }}</p>  </div>  
</template>  <script>  
import { ref, onMounted, onBeforeUnmount } from 'vue';  
import ChildComponent from './ChildComponent.vue';  
import { useMitt } from './useMitt';  export default {  components: {  ChildComponent,  },  setup() {  const { on, off } = useMitt();  const receivedMessage = ref(null);  onMounted(() => {  on('child-event', (message) => {  receivedMessage.value = message;  });  });  onBeforeUnmount(() => {  off('child-event');  });  return {  receivedMessage,  };  },  
};  
</script>

在这个例子中,ChildComponent 发射一个名为 child-event 的事件,并附带一条消息。ParentComponent 则监听这个事件,并在接收到消息时更新其状态。由于 ChildComponent 和 ParentComponent 都使用同一个 mitt 实例(通过 useMitt 函数获取),它们能够顺利地进行通信。

三、确保 useMitt 的单例性

代码如下(示例):

重要的是要确保在整个应用程序中只创建一个 mitt 实例,并通过 useMitt 函数共享它。这样可以避免在组件之间产生多个事件流,并确保事件的正确传播。在上面的例子中,useMitt.js 文件中的 emitter 是在模块作用域内创建的,因此每个导入 useMitt 的组件都会得到相同的实例。


总结

通过这种方法,你可以轻松地在 Vue 3 的多个组件之间使用 mitt 进行通信。只需确保所有组件都通过 useMitt 函数访问相同的 mitt 实例,然后就可以自由地发射和监听事件了。

童年啊,童年是永远的梦 梦里的小船,飘荡在彩虹的河流 童年的纸飞机,飞向云端 童年的歌谣,唱出心中的欢乐

这篇关于Vue3实战笔记(54)—揭秘Vue3实战:1分钟学会mitt,轻松玩转跨组件通讯的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1019231

相关文章

Spring AI与DeepSeek实战一之快速打造智能对话应用

《SpringAI与DeepSeek实战一之快速打造智能对话应用》本文详细介绍了如何通过SpringAI框架集成DeepSeek大模型,实现普通对话和流式对话功能,步骤包括申请API-KEY、项目搭... 目录一、概述二、申请DeepSeek的API-KEY三、项目搭建3.1. 开发环境要求3.2. mav

前端bug调试的方法技巧及常见错误

《前端bug调试的方法技巧及常见错误》:本文主要介绍编程中常见的报错和Bug,以及调试的重要性,调试的基本流程是通过缩小范围来定位问题,并给出了推测法、删除代码法、console调试和debugg... 目录调试基本流程调试方法排查bug的两大技巧如何看控制台报错前端常见错误取值调用报错资源引入错误解析错误

Vue中动态权限到按钮的完整实现方案详解

《Vue中动态权限到按钮的完整实现方案详解》这篇文章主要为大家详细介绍了Vue如何在现有方案的基础上加入对路由的增、删、改、查权限控制,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、数据库设计扩展1.1 修改路由表(routes)1.2 修改角色与路由权限表(role_routes)二、后端接口设计

Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

《Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)》文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一... 目录一、首先 npm 安装插件二、创建一个vue组件三、业务页面内 引用自定义组件:四、dhtmlx

Python与DeepSeek的深度融合实战

《Python与DeepSeek的深度融合实战》Python作为最受欢迎的编程语言之一,以其简洁易读的语法、丰富的库和广泛的应用场景,成为了无数开发者的首选,而DeepSeek,作为人工智能领域的新星... 目录一、python与DeepSeek的结合优势二、模型训练1. 数据准备2. 模型架构与参数设置3

Vue ElementUI中Upload组件批量上传的实现代码

《VueElementUI中Upload组件批量上传的实现代码》ElementUI中Upload组件批量上传通过获取upload组件的DOM、文件、上传地址和数据,封装uploadFiles方法,使... ElementUI中Upload组件如何批量上传首先就是upload组件 <el-upl

前端知识点之Javascript选择输入框confirm用法

《前端知识点之Javascript选择输入框confirm用法》:本文主要介绍JavaScript中的confirm方法的基本用法、功能特点、注意事项及常见用途,文中通过代码介绍的非常详细,对大家... 目录1. 基本用法2. 功能特点①阻塞行为:confirm 对话框会阻塞脚本的执行,直到用户作出选择。②

Java实战之利用POI生成Excel图表

《Java实战之利用POI生成Excel图表》ApachePOI是Java生态中处理Office文档的核心工具,这篇文章主要为大家详细介绍了如何在Excel中创建折线图,柱状图,饼图等常见图表,需要的... 目录一、环境配置与依赖管理二、数据源准备与工作表构建三、图表生成核心步骤1. 折线图(Line Ch

如何使用CSS3实现波浪式图片墙

《如何使用CSS3实现波浪式图片墙》:本文主要介绍了如何使用CSS3的transform属性和动画技巧实现波浪式图片墙,通过设置图片的垂直偏移量,并使用动画使其周期性地改变位置,可以创建出动态且具有波浪效果的图片墙,同时,还强调了响应式设计的重要性,以确保图片墙在不同设备上都能良好显示,详细内容请阅读本文,希望能对你有所帮助...

CSS3 最强二维布局系统之Grid 网格布局

《CSS3最强二维布局系统之Grid网格布局》CS3的Grid网格布局是目前最强的二维布局系统,可以同时对列和行进行处理,将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局,本文介... 深入学习 css3 目前最强大的布局系统 Grid 网格布局Grid 网格布局的基本认识Grid 网