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>
相关推荐
zwjapple3 小时前
docker-compose一键部署全栈项目。springboot后端,react前端
前端·spring boot·docker
像风一样自由20205 小时前
HTML与JavaScript:构建动态交互式Web页面的基石
前端·javascript·html
aiprtem6 小时前
基于Flutter的web登录设计
前端·flutter
浪裡遊6 小时前
React Hooks全面解析:从基础到高级的实用指南
开发语言·前端·javascript·react.js·node.js·ecmascript·php
why技术6 小时前
Stack Overflow,轰然倒下!
前端·人工智能·后端
幽络源小助理6 小时前
SpringBoot基于Mysql的商业辅助决策系统设计与实现
java·vue.js·spring boot·后端·mysql·spring
GISer_Jing6 小时前
0704-0706上海,又聚上了
前端·新浪微博
止观止6 小时前
深入探索 pnpm:高效磁盘利用与灵活的包管理解决方案
前端·pnpm·前端工程化·包管理器
whale fall6 小时前
npm install安装的node_modules是什么
前端·npm·node.js
烛阴6 小时前
简单入门Python装饰器
前端·python