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>
相关推荐
FuckPatience3 分钟前
Halcon 寻找方形Mark
前端·javascript·数据库
小陈工4 分钟前
Python Web开发入门(八):用户认证系统实现,给你的应用加上安全锁
开发语言·前端·数据库·python·安全·django·sqlite
weixin1997010801635 分钟前
《XMZ 商品详情页前端性能优化实战》
前端·性能优化
happymaker06261 小时前
vue中对list的函数处理方式总结,以及常见功能的实现方法
javascript·vue.js·list
还是大剑师兰特1 小时前
vueup/vue-quill 详细介绍(Vue3 富文本编辑器)
javascript·vue.js·ecmascript
蜡台1 小时前
Uniapp H5Builderx 预览Html 显示404问题解决
前端·uni-app
We་ct2 小时前
LeetCode 190. 颠倒二进制位:两种解法详解
前端·算法·leetcode·typescript
bigdargon2 小时前
【无标题】
vue.js
踩着两条虫2 小时前
AI驱动的Vue3应用开发平台深入探究(二十五):API与参考之Renderer API 参考
前端·javascript·vue.js·人工智能·低代码·前端框架·ai编程