mitt 事件发布-订阅库在 react 中的使用

mitt是一个轻量级的事件发布 - 订阅库,在 React 项目里,使用它能实现组件间的通信。下面来详细介绍一下 mitt 在 React 中的使用方法:

安装 mitt

在项目根目录下执行以下命令:

复制代码
npm install mitt

使用

  1. 新建一个 eventBus.js 文件,创建事件总线,并暴露出去:

    javascript 复制代码
    import mitt from 'mitt';
    const emitter = mitt();
    export default emitter;    
  2. 新建一个发送事件的组件 SenderComponent.js。 在按钮的点击事件处理函数里,借助emitter.emit方法发送一个名为message的事件,并且传递了一条消息。

javascript 复制代码
import React from 'react';
import emitter from './eventBus';

const SenderComponent = () => {
    const handleClick = () => {
        // 发送事件,事件名为 'message',并传递数据
        emitter.emit('message', 'Hello from SenderComponent!');
    };

    return (
        <button onClick={handleClick}>
            Send Message
        </button>
    );
};

export default SenderComponent;    
  1. 新建一个接收事件的组件ReceiverComponent.js 在useEffect钩子中,使用emitter.on方法监听message事件。当事件触发时,会执行对应的回调函数。组件卸载时,使用emitter.off方法移除监听器,以此避免内存泄漏。
javascript 复制代码
import React, { useEffect } from 'react';
import emitter from './eventBus';

const ReceiverComponent = () => {
    useEffect(() => {
        // 监听 'message' 事件
        const handleMessage = (message) => {
            console.log('Received message:', message);
        };

        emitter.on('message', handleMessage);

        // 组件卸载时移除监听器
        return () => {
            emitter.off('message', handleMessage);
        };
    }, []);

    return (
        <div>
            Waiting for messages...
        </div>
    );
};

export default ReceiverComponent;    

到此就完整实现了 mitt 的组件通信。

mitt 库同样适用于 vue,使用方法也是同上一样的步骤,只是要遵循 vue 的语法。

相关推荐
AI袋鼠帝4 小时前
火爆全网的Seedance2.0 十万人排队,我2分钟就用上了
前端
IT_陈寒4 小时前
React Hooks闭包陷阱:你以为的state可能早就过期了
前端·人工智能·后端
Jenlybein4 小时前
快速了解熟悉 Vite ,即刻上手使用
前端·javascript·vite
小码哥_常4 小时前
安卓开发避坑指南:全局异常捕获与优雅处理实战
前端
lihaozecq4 小时前
我用 1 天的时间 vibe coding 了一个多人德州扑克游戏
前端·react.js·ai编程
momo061174 小时前
AI Skill是什么?
前端·ai编程
言萧凡_CookieBoty4 小时前
用 AI 搞定用户系统:Superpowers 工程化开发教程
前端·ai编程
小小小小宇4 小时前
Go 语言协程
前端
牛奶4 小时前
5MB vs 4KB vs 无限大:浏览器存储谁更强?
前端·浏览器·indexeddb
牛奶4 小时前
setTimeout设为0就马上执行?JS异步背后的秘密
前端·性能优化·promise