Vue3 mitt 组件通信 - 附完整示例

mitt:事件总线,是第三方插件。

Vue2.x 使用 EventBus 进行组件通信,而 Vue3.x 中EventBus被弃用了,因此推荐使用 mitt.js。

目录

一、介绍

 1、官方文档

        1)npm网

2、官方示例

 二、准备工作

1、 安装依赖包

2、示例版本 

 三、使用步骤

1、在公共文件(utils)新建mitt.ts文件,简单封装下' mitt '

 注: TS的写法可参考官网的这个部分

2、使用

        1)派发页面

        2)监听页面

四、完整示例

1、mitt.ts

2、A.vue - 派发页面

3、B.vue - 监听页面


一、介绍

 1、官方文档

        1)npm网


mitt - npmmitt - npm

mitt - npmTiny 200b functional Event Emitter / pubsub.. Latest version: 3.0.1, last published: 7 months ago. Start using mitt in your project by running `npm i mitt`. There are 2189 other projects in the npm registry using mitt.https://www.npmjs.com/package/mitt

2、官方示例

 二、准备工作

1、 安装依赖包

npm install mitt --save

2、示例版本 

"mitt": "^2.1.0",

 三、使用步骤

1、在公共文件(utils)新建mitt.ts文件,简单封装下' mitt '

import mitt from 'mitt'

const emitter = new mitt()

export default emitter

 注: TS的写法可参考官网的这个部分

2、使用

        1)派发页面

import emitter from '../utils/mitt'

// 派发
emitter.emit('on-button-click', true);

        2)监听页面

import emitter from '../utils/mitt'

emitter.on('on-button-click', (e: boolean) => {
  ......
  事件处理
});

注:部分方法/数据的完整版在完整示例展示

四、完整示例

1、mitt.ts

        文件路径:src/utils/mitt.ts

import mitt from 'mitt'

const emitter = new mitt()

export default emitter

2、A.vue - 派发页面

        文件路径:src/views/A.vue

<template>
  <div class="a">
    <div @click="handleClick" style="cursor: pointer;">测试mitt</div>
  </div>
</template>

<script lang="ts" setup>
import emitter from '../utils/mitt'

// mitt的使用
function handleClick() {
  console.log(111);
  // 派发
  emitter.emit('on-button-click', true);
}
</script>

3、B.vue - 监听页面

        文件路径:src/views/B.vue

<template>
  <div class="b">
    B页面
  </div>
</template>

<script setup lang="ts">
import { onMounted, onUnmounted } from 'vue';
import emitter from '../utils/mitt'



// 监听
onMounted(() => {
  emitter.on('on-button-click', (e: boolean) => {
    console.log(2222);
    if (e) {
      console.log('接收到了emitter', e);
      ......
      事件处理
    }
  });
});

// 移除
onUnmounted(() => {
  emitter.off('on-button-click', () => {});
});

</script>

注:监听事件使用完移除,以免消耗性能

 欢迎扫码下方二维码关注VX公众号

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值