欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue3優(yōu)雅的實現(xiàn)跨組件通信的常用方法總結(jié)

 更新時間:2023年11月13日 09:15:50   作者:萌萌噠草頭將軍  
開發(fā)中經(jīng)常會遇到跨組件通信的場景,props?逐層傳遞的方法實在是太不優(yōu)雅了,所以今天總結(jié)下可以更加簡單的跨組件通信的一些方法,文中通過代碼實例講解的非常詳細,需要的朋友可以參考下

前言

開發(fā)中經(jīng)常會遇到跨組件通信的場景。props 逐層傳遞的方法實在是太不優(yōu)雅了,所以今天總結(jié)下可以更加簡單的跨組件通信的一些方法。

依賴注入

<!-- App.vue -->
<script setup lang="ts">
import { ref, provide } from "vue";
import Child from "./components/Child.vue";
const count = ref(0)
const updateCount = () => count.value ++
provide("count", {count, updateCount})
</script>

<template>
  <h4>公眾號:萌萌噠草頭將軍</h4>
  <div>{{ count }}</div>
  <button @click="updateCount">change</button>
  <Child />
</template>
<!-- Child.vue -->
<template>
  <Other />
</template>
  
<script setup lang='ts'>
import Other from "./other.vue"
</script>

在 setup 組件中,使用 inject 跨組件通信是最佳的方案。所以該模式下,是沒有提供event bus 事件總線。

但是在 option api 模式下,還需要額外的注冊,顯的有點麻煩。

<script lang='ts'>
export default {
  emits: ["some-name"]
}
</script>

屬性透傳

<!-- App.vue -->
<script setup lang="ts">
import { ref, provide } from "vue";
import Attr from "./components/Attr.vue";
const count = ref(0)
const updateCount = () => count.value ++
provide("count", {count, updateCount})
</script>

<template>
  <h4>公眾號:萌萌噠草頭將軍</h4>
  <div>{{ count }}</div>
  <button @click="updateCount">change</button>
  <Attr :count="count" :updateCount="updateCount" />
</template>
<!-- Attr.vue -->
<template>
  <div>attr component</div>
  <Child v-bind="$attrs" />
</template>
  
<script setup lang='ts'>
import Child from './Child.vue';
</script>

屬性透傳這種方式類似于react中手動透傳屬性。感覺有點暴力,但是又特別方便快捷。

function App (props) {
  return <Other {...props} />
}

Vue中默認透傳的屬性有 style、class、key。如果子組件也存在class、style,則會自動合并class、style。

如果你的子組件是根組件時,可以省略 v-bind="$attrs"。

<template>
  <Child />
</template>

狀態(tài)庫

狀態(tài)管理庫我們以Pinia為例。

<!-- App.vue -->
<script setup lang="ts">
import Other from "./components/Other.vue";
import { useCounterStore } from "./store/index"
const state = useCounterStore()
</script>

<template>
  <h4>公眾號:萌萌噠草頭將軍</h4>
  <div>{{ count }}</div>
  <button @click="updateCount">change</button>
  <Other />
</template>
import { defineStore } from "pinia" 
import { ref } from "vue"

export const useCounterStore = defineStore('counter', () => {
  const count = ref(0)
  function updateCount() {
    count.value++
  }

  return { count, updateCount }
})
<!-- Other.vue -->
<template>
  <div>pinia store</div>
  <div>{{ state.count }}</div>
  <button @click="state.updateCount">other change</button>
</template>
  
<script setup lang='ts'>
import { useCounterStore } from '../store';
const state = useCounterStore()
</script>

狀態(tài)管理庫最大的缺點是,沒法使用解構(gòu)語法。因為這會導(dǎo)致失去響應(yīng)式的能力。

事件總線

事件總線(event bus)比較特殊,因為在組合式API里不支持該方式,所以下面的例子適合 Option API 組件。

<!-- App.vue -->
<script setup lang="ts">
import { ref } from "vue";
import Other from "./components/Other.vue";
const count = ref(0)
const updateCount = () => count.value ++
</script>

<template>
  <h4>公眾號:萌萌噠草頭將軍</h4>
  <div>{{ count }}</div>
  <button @click="updateCount">change</button>
  <Other @updateCount="updateCount()" />
</template>
<!-- Other.vue -->
<template>
  <div>eventBus store</div>
  <button @click="$emit('updateCount')">other change</button>
</template>
  
<script lang='ts'>
export default {
  emits: ["updateCount"]
}
</script>

事件總線更適合傳遞事件。

自定義事件

但是有時候,你可能非常想使用事件總線的方式在 setup 組件中傳遞事件,這時候我們可以使用自定義的事件的方式實現(xiàn)這種功能。

下面是實現(xiàn)。

class EventBus {
  constructor() {
    this.events = {};
  }

  // 訂閱事件
  on(eventName, callback) {
    if (!this.events[eventName]) {
      this.events[eventName] = [];
    }
    this.events[eventName].push(callback);
  }

  // 發(fā)布事件
  emit(eventName, eventData) {
    const eventCallbacks = this.events[eventName];
    if (eventCallbacks) {
      eventCallbacks.forEach(callback => {
        callback(eventData);
      });
    }
  }

  // 取消訂閱事件
  off(eventName, callback) {
    const eventCallbacks = this.events[eventName];
    if (eventCallbacks) {
      this.events[eventName] = eventCallbacks.filter(cb => cb !== callback);
    }
  }
}

export const eventBus = new EventBus()
<!-- App.vue -->
<script setup lang="ts">
import { ref } from "vue";
import Other from "./components/Other.vue";
import { eventBus } from "./store/eventBus";
const count = ref(0)
const updateCount = () => count.value ++
eventBus.on("updateCount", updateCount)
</script>

<template>
  <h4>公眾號:萌萌噠草頭將軍</h4>
  <div>{{ count }}</div>
  <button @click="updateCount">change</button>
  <Other @updateCount="updateCount()" />
</template>
<!-- Other.vue -->
<template>
  <div>eventBus</div>
  <button @click="eventBus.emit('updateCount', null)">other change</button>
</template>
  
<script setup lang='ts'>
import { eventBus } from "../store/eventBus";
</script>

當(dāng)然,我們這里不止可以使用 event bus,發(fā)布訂閱模式也很適合??梢詤⒖嘉乙郧暗脑O(shè)計模式的文章實現(xiàn)這個功能。

總結(jié)

每種方式都有自己的優(yōu)點和缺點,根據(jù)使用場景選擇最合適的才能算是最優(yōu)的方案。

以上就是Vue3優(yōu)雅的跨組件通信的常用方法總結(jié)的詳細內(nèi)容,更多關(guān)于Vue3跨組件通信的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue的@change的用法及操作代碼

    vue的@change的用法及操作代碼

    @change 是 Vue.js 中用于監(jiān)聽表單元素值變化的事件處理器,這篇文章主要介紹了vue的@change的用法,需要的朋友可以參考下
    2023-10-10
  • 解決vue單頁面修改樣式無法覆蓋問題

    解決vue單頁面修改樣式無法覆蓋問題

    這篇文章主要介紹了vue單頁面修改樣式無法覆蓋問題,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • 關(guān)于vite+vue3打包部署問題

    關(guān)于vite+vue3打包部署問題

    這篇文章主要介紹了關(guān)于vite+vue3打包部署問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • vue3 Class 與 Style 綁定操作方法

    vue3 Class 與 Style 綁定操作方法

    數(shù)據(jù)綁定的一個常見需求場景是操縱元素的 CSS class 列表和內(nèi)聯(lián)樣式,因為 class 和 style 都是 attribute,我們可以和其他 attribute 一樣使用 v-bind 將它們和動態(tài)的字符串綁定,這篇文章主要介紹了vue3 Class 與 Style 綁定操作方法,需要的朋友可以參考下
    2024-05-05
  • vue指令中的v-once用法

    vue指令中的v-once用法

    這篇文章主要介紹了vue指令中的v-once用法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue組件實現(xiàn)旋轉(zhuǎn)木馬動畫

    Vue組件實現(xiàn)旋轉(zhuǎn)木馬動畫

    這篇文章主要為大家詳細介紹了Vue組件實現(xiàn)旋轉(zhuǎn)木馬動畫效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • vue導(dǎo)出excel多層表頭的實現(xiàn)方案詳解

    vue導(dǎo)出excel多層表頭的實現(xiàn)方案詳解

    這篇文章主要為大家詳細介紹了vue導(dǎo)出excel多層表頭的實現(xiàn)方案,文中的示例代碼簡潔易懂,具有一定的借鑒價值,有需要的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2025-04-04
  • vue導(dǎo)出excel無法打開問題及解決

    vue導(dǎo)出excel無法打開問題及解決

    在Vue項目中導(dǎo)出Excel文件時,需在請求中設(shè)置responseType為'blob'或'arraybuffer',否則文件可能損壞無法打開,正確配置確保瀏覽器正確解析二進制數(shù)據(jù)流,生成有效Excel文件
    2025-08-08
  • vue 組件中使用 transition 和 transition-group實現(xiàn)過渡動畫

    vue 組件中使用 transition 和 transition-group實現(xiàn)過渡動畫

    本文給大家分享一下vue 組件中使用 transition 和 transition-group 設(shè)置過渡動畫,總結(jié)來說可分為分為 name 版, js 鉤子操作類名版, js 鉤子操作行內(nèi)樣式版,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友參考下吧
    2019-07-07
  • Vue使用Proxy代理后仍無法生效的解決

    Vue使用Proxy代理后仍無法生效的解決

    這篇文章主要介紹了Vue使用Proxy代理后仍無法生效的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11

最新評論