Vue3兄弟组件传值之mitt的超详细讲解
作者:潇湘轮回 发布时间:2023-07-02 16:56:04
标签:mitt,兄弟组件,传值
前言
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


猜你喜欢
- 【题目】keras中的Merge层(实现层的相加、相减、相乘)详情请参考:Merge层一、层相加keras.layers.Add()添加输入
- link(){var olink = getElementById("link");var text = olink.i
- 0x00 前言eval是Python用于执行python表达式的一个内置函数,使用eval,可以很方便的将字符串动态执行。比如下列代码:&g
- 集合特点:集合对象是一组无序排列的可哈希的值:集合成员可以做字典的键,与列表和元组不同,集合无法通过数字进行索引。此外,集合中的元素不能重复
- 前言上一篇文章中有同学提到路由鉴权,由于时间关系没有写,本文将针对这一特性对 vue 和 react 做专门说明,希望同学看了以后能够受益匪
- Python作为一种脚本语言,其要求强制缩进,使其易读、美观,它的数据类型可以实现自动转换,而不需要像C、Java那样给变量定义数据类型,使
- CSS布局中可以用javascript判断浏览器版本看如下的javascript脚本: if (window.XMLHt
- Oracle 数据库启动Oracle shutdown的时候突然断电,导致使用sql/plus启动时无法连接到数据库,具体描述为: conn
- 由于最近需要做项目,需要进行分词等,查了资料之后,发现python NLTK很强大,于是就想试试看。在网上找了很多安装资料,都不太完整,下载
- 不同的是setInterval会每隔指定的时间段就执行一次代码,具有重复性。而setTimeout只会调用后执行一次。 下面通过函数的建立和
- 搭建FTP,或者是搭建网络文件系统,这些方法都能够实现Linux的目录共享。但是FTP和网络文件系统的功能都过于强大,因此它们都有一些不够方
- requests安装和使用下载安装:pip install requests#requests模块import requests#发送请求
- 本文实例讲述了Python实现SVN的目录周期性备份方法。分享给大家供大家参考。具体如下:起因:今天用SVN时,不小心把远程SVN服务器上的
- 目录01 安装02 剪辑01 安装对视频进行批量剪辑,需要三个库,分别是Moviepy库和Pathlib库,还有Tkinter库。首先我们对
- 你一定想下载一下感兴趣的网页,以便慢慢欣赏吧!利用FrontPage能够轻松做到这一点,甚至可以下载整个站点,当然这里只能下载静态的页面。启
- 一、StreamVR问题:1.运行项目时不显示手柄控制器:出现这种情况一般会在头显中提示不能加载按键配置文件,出现这种提示时请直接打开ste
- Guide to the Section 508 Standards for Electronic and Information Tech
- ASP由于是一种古老的语言,它的一些功能对UTF-8支持非常差。比如,你想生成一个UTF-8格式的文件,使用常用的 scrīpting.Fi
- 【原文地址】New "Orcas" Language Feature: Query Syntax 【原文发表日期】 Sa
- 获取需要使用到正则的两个对象:使用的是用正则对象Pattern 和匹配器Matcher。用法:范例: Pattern p = Pattern