溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue3兄弟組件傳值之mitt怎么安裝使用

發(fā)布時間:2022-06-16 13:50:00 來源:億速云 閱讀:1662 作者:iii 欄目:開發(fā)技術

本篇內容介紹了“Vue3兄弟組件傳值之mitt怎么安裝使用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

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

  • 首先它足夠小,僅有200bytes。

  • 其次支持全部事件的監(jiān)聽和批量移除。

  • 它還不依賴 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 發(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>

“Vue3兄弟組件傳值之mitt怎么安裝使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注億速云網(wǎng)站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI