vue3+ts 中使用mitt进行跨组件通信

mitt插件的使用

安装插件

官方文档

javascript 复制代码
pnpm i mitt --s //我用的pnpm
或
npm i --s mitt
或
yarn add mitt

进行封装一个模块,对外暴露一个Mitt实例

1、在utils文件夹下新建mitt(例如 mitt.ts),用于初始化并导出 mitt 实例:

javascript 复制代码
// src/eventBus.ts
import mitt from 'mitt';

// 定义事件类型
type Events = {
  someEvent: string;
  anotherEvent: number;
  // 这里可以定义其他事件类型
};

// 创建一个事件总线实例
const mitter = mitt<Events>();

export default mitter;

使用

通过emit触发/on监听

javascript 复制代码
//在需要传送数据的组件使用
<template>
  <div>
    <button @click="emitEvent">Emit Event</button>
  </div>
</template>

<script lang="ts" setup>
import { ref } from 'vue';
import mitter from '@/utils/mitt';

const emitEvent = () => {
  mitter.emit('someEvent', 'Hello from component!');
};
</script>
javascript 复制代码
// 在需要接收的组件中使用
<template>
  <div>
    <p>{{ message }}</p>
  </div>
</template>

<script lang="ts" setup>
import { ref, onMounted, onBeforeUnmount } from 'vue';
import mitter from '@/utils/mitt';

const message = ref('');

const handleSomeEvent = (payload: string) => {
  message.value = payload;
};

onMounted(() => {
  mitter.on('someEvent', handleSomeEvent);
});

// 记得移除哦
onBeforeUnmount(() => {
  mitter.off('someEvent', handleSomeEvent);
});

// ======================或者
mitter.on('someEvent', (val: string)=>{
  message.value = val
 });
</script>
相关推荐
web守墓人2 分钟前
【前端】garn:使用go实现一款类似yarn的依赖管理器
前端
全栈陈序员9 分钟前
Vue 实例挂载的过程是怎样的?
前端·javascript·vue.js·学习·前端框架
+VX:Fegn089534 分钟前
计算机毕业设计|基于springboot + vue健康茶饮销售管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
Bruce_Liuxiaowei40 分钟前
一键清理Chrome浏览器缓存:批处理与PowerShell双脚本实现
前端·chrome·缓存
怒放的生命199140 分钟前
Vue 2 vs Vue 3对比 编译原理不同深度解析
前端·javascript·vue.js
GDAL1 小时前
html返回顶部实现方式对比
前端·html·返回顶部
Violet_YSWY1 小时前
ES6 () => ({}) 语法解释
前端·ecmascript·es6
LYFlied1 小时前
【每日算法】LeetCode 279. 完全平方数(动态规划)
前端·算法·leetcode·面试·动态规划
小北方城市网1 小时前
第7课:Vue 3应用性能优化与进阶实战——让你的应用更快、更流畅
前端·javascript·vue.js·ai·性能优化·正则表达式·json
向下的大树1 小时前
React 环境搭建 + 完整 Demo 教程
前端·react.js·前端框架