Vue3兄弟組件傳值之mitt的超詳細(xì)講解
前言
Vue2.x 使用 EventBus 事件總線進(jìn)行兄弟組件通信,而在Vue3中事件總線模式已經(jīng)被移除,官方建議使用外部的、實(shí)現(xiàn)了事件觸發(fā)器接口的庫(kù),例如 mitt 或 tiny-emitter。
比起 Vue 實(shí)例上的 EventBus,mitt.js 好在哪里呢?
- 首先它足夠小,僅有200bytes。
- 其次支持全部事件的監(jiān)聽(tīng)和批量移除。
- 它還不依賴(lài) Vue 實(shí)例,可以跨框架使用,React 或者 Vue,甚至 jQuery 項(xiàng)目都能使用同一套庫(kù)。
項(xiàng)目中安裝mitt
npm install --save mitt
使用方式一:在原型中聲明
一、在 main.ts\color{#ef2d26}{main.ts}main.ts 中注冊(cè)掛載到全局
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 發(fā)送信息
<template>
<div class="home-container">
<p>這里是home組件</p>
<button @click="sendMitt">$mitt發(fā)送數(shù)據(jù)</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>接收到的數(shù)據(jù):{{ 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 發(fā)送信息
<template>
<div class="home-container">
<p>這里是home組件</p>
<button @click="sendMitt">$mitt發(fā)送數(shù)據(jù)</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>接收到的數(shù)據(jù):{{ 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>總結(jié)
到此這篇關(guān)于Vue3兄弟組件傳值之mitt的文章就介紹到這了,更多相關(guān)Vue3兄弟組件傳值mitt內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue3.0實(shí)現(xiàn)無(wú)限級(jí)菜單
這篇文章主要為大家詳細(xì)介紹了基于Vue3.0實(shí)現(xiàn)無(wú)限級(jí)菜單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07
vue新手入門(mén)出現(xiàn)function () { [native code]&nbs
這篇文章主要介紹了vue新手入門(mén)出現(xiàn)function () { [native code] }錯(cuò)誤的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
vue3解決各場(chǎng)景l(fā)oading過(guò)度的五種方法
這篇文章主要為大家詳細(xì)介紹了vue3中解決各場(chǎng)景l(fā)oading過(guò)度的五種方法,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以學(xué)習(xí)一下2023-11-11
解決Vue2.0 watch對(duì)象屬性變化監(jiān)聽(tīng)不到的問(wèn)題
今天小編就為大家分享一篇解決Vue2.0 watch對(duì)象屬性變化監(jiān)聽(tīng)不到的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09
Vue+Element樹(shù)形表格實(shí)現(xiàn)拖拽排序示例
本文主要介紹了Vue+Element樹(shù)形表格實(shí)現(xiàn)拖拽排序示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
Vue中的methods、computed計(jì)算屬性和watch監(jiān)聽(tīng)屬性的使用和區(qū)別解析
這篇文章主要介紹了Vue中的methods、computed計(jì)算屬性和watch監(jiān)聽(tīng)屬性的使用和區(qū)別,本文通過(guò)示例代碼給大家介紹的非常詳細(xì)對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-01-01
vue中echarts自動(dòng)輪播tooltip問(wèn)題
這篇文章主要介紹了vue中echarts自動(dòng)輪播tooltip問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
vscode不支持nvue語(yǔ)法高亮的解決辦法(圖文詳解)
這篇文章主要介紹了vscode不支持nvue語(yǔ)法高亮的解決辦法,用vscode開(kāi)發(fā)uniapp會(huì)遇到用.nvue開(kāi)發(fā)的時(shí)候。但是vscode并沒(méi)有提供.nvue的語(yǔ)法高亮,這篇文章給剛用vscode寫(xiě).nvue的讀者,需要的朋友可以參考下2023-02-02

