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 实例,然后就可以自由地发射和监听事件了。

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/19797.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【QT】qcombox的信号使用小细节,activated(int)和currentIndexChanged(int)

activated(int)和currentIndexChanged(int)这两个信号在QComboBox中都有传递当前索引的功能&#xff0c;但它们触发的条件有所不同&#xff0c;导致它们适用于不同的场景。以下是它们之间的主要区别&#xff1a; 1. activated(int) 触发条件&#xff1a;当用户主动选择了一个…

Python中的 Lambda 函数

大家好&#xff0c;在 Python 编程的世界里&#xff0c;有一种功能强大却不常被提及的工具&#xff0c;它就是 Lambda 函数。这种匿名函数在 Python 中拥有着令人惊叹的灵活性和简洁性&#xff0c;却常常被许多开发者忽视或者只是将其当作一种附加功能。Lambda 函数的引入&…

Java18+ springboot+mysql +Thymeleaf 技术架构开发的全套同城服务家政上门系统源码(APP用户端+APP服务端+PC管理端)

Java springbootmysql Thymeleaf 技术架构开发的全套同城服务家政上门系统源码&#xff08;APP用户端APP服务端PC管理端&#xff09; 家政上门预约系统&#xff1a;该系统综合运用springboot、java1.8、vue移动支付、微信授权登录等技术&#xff0c;由用户小程序、站长小程序、…

C#面:.Net中会存在内存泄漏吗,请简单描述

在C# .NET中&#xff0c;内存泄漏是可能存在的。内存泄漏指的是在程序运行过程中&#xff0c;分配的内存空间没有被正确释放&#xff0c;导致这些内存空间无法再被其他部分使用&#xff0c;从而造成内存的浪费。 在C# .NET中&#xff0c;垃圾回收器&#xff08;Garbage Collec…

亚马逊云科技峰会盛大举行 | 光环新网携光环云数据以高性能智算服务助力企业创新发展

2024年5月29日&#xff0c;云计算行业的年度盛典”2024亚马逊云科技中国峰会”在上海世博中心再次盛大启幕。作为全球领先的云计算服务提供商&#xff0c;亚马逊云科技峰会聚焦前沿科技&#xff0c;与来自不同行业、不同科技领域的优秀企业和用户共同探索AI时代的云端创新发展。…

QProcess类实现将子进程的窗口嵌入的主进程中

在主进程中创建子进程,子进程也是通过qt新建的qwidget窗口的应用程序. bool CncOpWindows::LoadVisionMeasureApp() {QString cmd QCoreApplication::applicationDirPath();int iCamAppType 0;switch (iCamAppType){case 0:cmd "/ImageGrab.exe";//子程序执行文件地…

Java知识大纲

一、基础 (一) Java的应用范围和相关组件 (二)搭建开发环境 (三)类文件定义 (四)编写第一个程序 (五)编译和运行 (六)变量定义和使用 (七)字符串的定义和使用 (八)变量类型转换 (九)静态变量 (十)基本运算、逻辑运算、位运算 (十一)流程结构(条件&#xff0c;循环&a…

华为官网的自助申诉

代码&#xff1a;如下 <!DOCTYPE html> <html lang"en"> <head> <meta charset"UTF-8"> <meta name"viewport" content"widthdevice-width, initial-scale1.0"> <title>Document</title> …

MatLab命令行常用命令记录

文章目录 MatLab常用命令行MatLab常用按键标点说明 MatLab常用命令行 Matlab常用命令用来管理目录、命令、函数、变量、工作区、文件及窗口。常用命令如下表 命令作用cd显示或改变当前文件夹load加载指定文件的变量dir显示当前文件夹或指定目录下的文件diary日志文件命令type…

Facebook会话过期是什么情况?如何解决?

如果你点开这篇文章&#xff0c;可能你曾经遇到过Facebook会话过期的错误。无论你是在抓取Facebook数据还是只是浏览动态&#xff0c;看到这个错误消息都会让人很不爽。但别担心&#xff0c;我们将会分享解决Facebook会话过期错误的最佳方法&#xff0c;这样你就可以迅速修复问…

TemuTHunt使用简单介绍

数据列表 详情 列表及详情 数据监控 ------------------------------------------------华丽的分割线------------------------------------ 数据列表 商品详情 更多功能及分析报表 是不是很好用。

算法学习笔记(7.3)-贪心算法(最大切分乘问题)

目录 ##问题描述 ##问题思考 ##贪心策略确定 ##代码实现 ##时间复杂度 ##正确性验证 ##问题描述 给定一个正整数 &#x1d45b; &#xff0c;将其切分为至少两个正整数的和&#xff0c;求切分后所有整数的乘积最大是多少 ##问题思考 假设我们将 &#x1d45b; 切分为 &…

SQL入门教程----基础知识

SQL&#xff08;Structured Query Language&#xff09;是一种用于管理和操作关系数据库的标准语言。它主要用于执行查询、插入、更新和删除数据库中的数据。以下是一个SQL入门教程&#xff0c;涵盖基础概念、基本操作和一些常用的SQL命令。 1. 基本概念 数据库&#xff1a;存…

字符串转换为字节数组、16进制转换为base64、base64转换为字符串数组、base64转换为16进制(微信小程序)

1、字符串转换为字节数组 // 字符串转为字节数组 function stringToByteArray(str) {var array new Uint8Array(str.length);for (var i 0; i < str.length; i) {array[i] str.charCodeAt(i);}return array; } 2、16进制转换为base64 // 16进制转换为base64 function H…

linux开发之设备树六、linux下pinctrl子系统管理设置pin管脚的复用功能(一般原厂提供)

客户端的编写格式是固定的&#xff0c;不管哪家原厂的处理器&#xff0c;格式都是一样的 对于服务端部分是原厂提供&#xff0c;各个芯片肯定就不一样了&#xff0c;主要在于编写的格式不同 pinctrl客户端写法 使用pinctrl设置管脚复用 在kernel/arch/arm64/boot/dts/rockchi…

清风雅致·林曦老师的中国画美育直播课 你想了解的都在这里

大家期待已久的《清风雅致林曦老师的中国画美育直播课》开启报名啦~这个夏天&#xff0c;林曦老师将带你画完十幅重要的册页图&#xff0c;明代杜琼的《南村别墅图》。在此期间&#xff0c;暄桐教室除了收到了大家的“心心念念”和“满怀期待”&#xff0c;还有一连串“小问号”…

将 cuda kernel 编译成 ptx 和 rocm的hip asm

1&#xff0c;cuda 源码编译 cuda_a_one.cu __global__ void NNNNNVVVVV_one(int *A) {A[333] 777; }编译命令&#xff1a; %.ptx: %.cu nvcc -archsm_70 -ptx $< -o $ 生成的结果&#xff1a; 2, hip 源码编译 hip_a_one.hip__global__ void AAAAAMMMMM_one(int *A…

Redis之持久化、集群

1. Redis持久化 Redis为什么需要持久化?因为Redis的数据我们都知道是存放在内存中的&#xff0c;那么每次关闭或者机器断电&#xff0c;我们的数据旧丢失了。 因此&#xff0c;Redis如果想要被别人使用&#xff0c;这个问题就需要解决&#xff0c;怎么解决呢?就是说我们的数…

安全风险 - 检测设备是否为模拟器

在很多安全机构的检测中&#xff0c;关于模拟器的运行环境一般也会做监听处理&#xff0c;有的可能允许执行但是会提示用户&#xff0c;有的可能直接禁止在模拟器上运行我方APP 如何判断当前 app 是运行在Android真机&#xff0c;还是运行在模拟器? 可能做 Framework 的朋友思…

广告联盟如何实现

在互联网时代&#xff0c;各种广告形式无处不在&#xff0c;无论是在社交媒体、网站还是APP上&#xff0c;广告无处不在。然而&#xff0c;广告对于一些人来说并不只是一种干扰&#xff0c;还可以是一种赚钱方式。下载广告联盟看广告能赚钱吗?这是一个很有趣的问题&#xff0c…