Mitt —— 小而美的事件总线库

简介

Mitt是一个小巧而强大的 JavaScript 事件总线库,用于处理事件的发布和订阅。

用法示例

1、使用vite创建示例项目

项目名称:mitt-demo

框架:vue.js 3

bash 复制代码
$ yarn create vite

√ Project name: ... mitt-demo
√ Select a framework: >> Vue
√ Select a variant: >> JavaScript

2、进入示例项目根目录并安装依赖

bash 复制代码
# 进入项目根目录
$ cd mitt-demo
# 安装依赖
$ yarn

3、在项目中安装mitt

bash 复制代码
# 安装mitt
$ yarn add mitt

4、创建bus.js文件

src文件夹下创建utils文件夹,然后在utils文件夹下创建bus.js文件,bus.js文件内容如下:

js 复制代码
import mitt from 'mitt'
// 创建事件总线实例
const emitter = mitt()
export default emitter

我们在bus.js文件中通过mitt()创建了一个事件总线实例,用于发布和订阅事件。

5、创建事件发布组件 ------ EventPublisher.vue

src/components文件夹下创建事件发布组件 ------ EventPublisher.vue,文件内容如下:

vue 复制代码
<script setup>
import { ref } from 'vue'
import emitter from '../utils/bus'

const count = ref(0)

// 事件发布方法
const publish = () => {
  console.log('== 发布事件 ==')
  emitter.emit('incr', count.value += 1)
}
</script>

<template>
  <button @click="publish">发布事件</button>
</template>

<style scoped>
</style>

6、创建事件监听组件 ------ EventListener.vue

src/components文件夹下创建事件监听组件 ------ EventListener.vue,文件内容如下:

vue 复制代码
<script setup>
import { ref, onBeforeMount, onMounted } from 'vue'
import emitter from '../utils/bus'

const count = ref(0)

onMounted(() => {
  // 监听事件
  console.log('== 监听事件 ==')
  emitter.on('incr', (res) => {
    count.value = res
  });
})

onBeforeMount(() => {
  // 取消监听
  console.log('== 取消监听 ==')
  emitter.off('incr')
});
</script>

<template>
  <div class="listener">消息内容:{{ count }}</div>
</template>

<style scoped>
.listener {
  background-color: beige;
}
</style>

7、修改App.vue

App.vue中引入事件发布组件、事件监听组件。

vue 复制代码
<script setup>
import EventPublisher from './components/EventPublisher.vue'
import EventListener from './components/EventListener.vue'
</script>

<template>
  <event-publisher></event-publisher>
  <event-listener></event-listener>
</template>

<style scoped>
</style>

8、启动项目,查看效果

参考

相关推荐
关中老四19 小时前
【原生JS甘特图MZGantt 】如何给父任务设置独立进度条
前端·javascript·甘特图
英俊潇洒美少年19 小时前
react 18 的fiber算法
前端·算法·react.js
xiegwei19 小时前
android Compose 图片星星评分组件
android·前端·elementui
Irene199119 小时前
ES13 # 私有字段( Private Fields) 语法:在类中定义真正的私有属性
javascript·私有字段
小鹿软件办公19 小时前
Firefox 149 正式推送:多任务处理升级,五大新功能详解
前端·firefox
evering19 小时前
遍历备份 Chrome | Edge 浏览器插件目录
前端·chrome·crx
WiChP19 小时前
【V0.1B4】从零开始的2D游戏引擎开发之路
前端·javascript·游戏引擎
意法半导体STM3219 小时前
【官方原创】STM32CubeProgrammer与STM32 Bootloader连接全流程实战指南 LAT1631
开发语言·前端·javascript·stm32·单片机·嵌入式硬件
薛定谔的悦19 小时前
《储能系统中的故障定位》
java·服务器·前端
慧一居士19 小时前
Vue项目中使用的首选的依赖库如VueUse等,使用场景和使用示例介绍
前端·vue.js