Vue3兄弟组件传值之mitt的超详细讲解

作者:潇湘轮回 时间:2023-07-02 16:56:04 

前言

Vue2.x 使用 EventBus 事件总线进行兄弟组件通信,而在Vue3中事件总线模式已经被移除,官方建议使用外部的、实现了事件触发器接口的库,例如 mitt 或 tiny-emitter。

比起 Vue 实例上的 EventBus,mitt.js 好在哪里呢?

  • 首先它足够小,仅有200bytes。

  • 其次支持全部事件的监听和批量移除。

  • 它还不依赖 Vue 实例,可以跨框架使用,React 或者 Vue,甚至 jQuery 项目都能使用同一套库。

项目中安装mitt

npm install --save mitt

使用方式一:在原型中声明

一、在 main.ts\color{#ef2d26}{main.ts}main.ts 中注册挂载到全局

import { createApp } from 'vue'
import App from './App.vue'
import mitt from 'mitt'
import router from "./router";

const app = createApp(App)

// vue3挂载到全局
app.config.globalProperties.$mitt = mitt();

app.use(router).mount('#app')

二、在home.vue组件中使用 emit\color{#ef2d26}{emit}emit 发送信息

<template>
   <div class="home-container">
       <p>这里是home组件</p>
       <button @click="sendMitt">$mitt发送数据</button>
       <About></About>
   </div>
</template>

<script lang="ts" setup>
import { getCurrentInstance, ref, ComponentInternalInstance } from 'vue';
import About from '../about/about.vue'

const { appContext } = getCurrentInstance() as ComponentInternalInstance;
const money = ref<number>(98);

const sendMitt = () => {
   appContext.config.globalProperties.$mitt.emit('moneyEvent', money.value += 2);
}

</script>

<style lang="less">
</style>

二、在about.vue组件中使用 on\color{#ef2d26}{on}on 接收信息

<template>
   <div class="about-container">
       <p>这里是about组件</p>
       <p>接收到的数据:{{ amount }}</p>
   </div>
</template>

<script lang="ts" setup>
import { ref, getCurrentInstance, ComponentInternalInstance, onBeforeMount, onMounted } from 'vue';

const amount = ref(0);
const { appContext } = getCurrentInstance() as ComponentInternalInstance;

onMounted(() => {
   appContext.config.globalProperties.$mitt.on('moneyEvent', (res: number) => {
       amount.value = res;
   })
})

onBeforeMount(() => {
   appContext.config.globalProperties.$mitt.off('moneyEvent');
});

</script>

<style lang="less">
.about-container {
   background-color: #f0f0f0;
}
</style>

使用方式二:在组件中引用

一、新建 bus.ts\color{#ef2d26}{bus.ts}bus.ts 文件

import mitt from "mitt";
const emiter = mitt();
export default emiter;

二、在home.vue组件中引入并使用 emit\color{#ef2d26}{emit}emit 发送信息

<template>
   <div class="home-container">
       <p>这里是home组件</p>
       <button @click="sendMitt">$mitt发送数据</button>
       <About></About>
   </div>
</template>

<script lang="ts" setup>
import { ref } from 'vue';
import About from '../about/about.vue'
import emitter from '../../utils/bus'

const money = ref<number>(98);

const sendMitt = () => {
   emitter.emit('moneyEvent', money.value += 2);
}
</script>

<style lang="less">
</style>

二、在about.vue组件中引入并使用 on\color{#ef2d26}{on}on 接收信息

<template>
   <div class="about-container">
       <p>这里是about组件</p>
       <p>接收到的数据:{{ amount }}</p>
   </div>
</template>

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

const amount = ref(0);

onMounted(() => {
   emitter.on('moneyEvent', (res: any) => {
       amount.value = res;
   });
})

onBeforeMount(() => {
   emitter.off('moneyEvent');
});

</script>

<style lang="less">
.about-container {
   background-color: #f0f0f0;
}
</style>

来源:https://juejin.cn/post/7106311753717252132

标签:mitt,兄弟组件,传值
0
投稿

猜你喜欢

  • 用python实现弹球小游戏

    2023-10-25 06:57:31
  • 详解springboot 使用c3p0数据库连接池的方法

    2024-01-19 04:59:09
  • PHP一文带你搞懂游戏中的抽奖算法

    2024-06-05 09:38:21
  • python通过函数属性实现全局变量的方法

    2023-08-25 04:54:20
  • js实现遮罩层弹出框的方法

    2024-02-23 09:01:33
  • python中正则的使用指南

    2023-09-10 18:24:51
  • Oracle捕获问题SQL解决CPU过渡消耗

    2010-07-21 13:14:00
  • mysql怎么设置最大连接数详解

    2024-01-24 04:44:55
  • c#将Excel数据导入到数据库的实现代码

    2024-01-25 21:53:43
  • python 实现简单的FTP程序

    2021-03-29 10:33:00
  • 纯ASP结合VML生成完美图-饼图

    2010-05-11 16:49:00
  • sqlserver数据库大型应用解决方案经验总结

    2024-01-26 13:38:52
  • Sql Server中的视图介绍

    2024-01-14 14:31:22
  • MySQL数据库基础篇SQL窗口函数示例解析教程

    2024-01-24 22:20:54
  • asp中去除html中style,javascript,css代码

    2011-02-16 11:18:00
  • OracleEXP和IMP用法和介绍

    2010-07-28 13:18:00
  • python多线程下信号处理程序示例

    2021-07-06 05:58:51
  • Python中文件的写入读取以及附加文字方法

    2021-03-03 12:05:15
  • Python Numpy计算各类距离的方法

    2022-12-03 13:52:53
  • Python re正则表达式元字符分组()用法分享

    2021-05-15 12:31:56
  • asp之家 网络编程 m.aspxhome.com