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

Vue組件之事件總線和消息發(fā)布訂閱詳解

 更新時間:2022年02月16日 11:49:33   作者:我會努力變強的  
這篇文章主要為大家詳細介紹了Vue組件之事件總線和消息發(fā)布訂閱,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助

簡介

主要介紹事件總線的定義和編寫方法和Vue是如何實現(xiàn)消息的訂閱與發(fā)布的。

事件總線

事件總線是組件間通信的一種方式,適用于任意組件間的通信,比如毫不相干的兩個組件、父子組件間、后代組件等等,都能通信。

事件總線有兩個特性:

  • 是一個vue組件實例或者一個vue實例,充當一個消息中轉站,如果A、B組件想要通信,那么A組件存消息到中轉站,B消息拿,或者反過來。
  • 所有組件都要能獲取到事件總線。

如果A、B組件間通信,如果A發(fā)送數據給B的情況下,需要以下步驟:

大前提是,需要創(chuàng)建一個事件總線,通常使用vm實例本身作為事件總線,并把他在一定的時機保存在Vue構造函數的原型對象中,因為組件實例的原型對象的原型對象=vue實例的原型對象,所以這樣所有的組件實例都是獲取到事件總線。

1.B(接收方)需要往事件總線總綁定一個自定義事件,并設置事件回調。

2.A(發(fā)送方)想要發(fā)送數據時,只需觸發(fā)B在事件總線綁定的自定義事件,并把數據傳過去即可。

在這里插入圖片描述

main.js:

//引入vue依賴
import Vue from 'vue'
//引入組件App
import App from './App.vue'

// 關閉生產提示
Vue.config.productionTip = false

//創(chuàng)建一個vue實例
new Vue({
  render: h => h(App),
  beforeCreate(){
    //通常在beforeCreate生命周期函數中進行事件總線的設置。
    //下面代碼就是把vm對象本身設置到Vue的原型對象中,屬性名通常是$bus,這個不強制
    Vue.prototype.$bus = this;
  }

  //配置該vue實例管理id為app的容器
}).$mount('#app')

在這里插入圖片描述

App.vue:

<template>
    <!-- 編寫結構 -->
    <div>
        <A></A>
    <hr>
    <B></B>
    </div>
</template>

<script>


//修改后的
//引入A組件和B組件,涉及es模塊化的語法
import A from "./components/A.vue"
import B from "./components/B.vue"

export default {


    components:{
        //注冊組件
        A,
        B
    }
}
</script>

<style>

</style>

B.vue:

<template>
    <div>
        <div>B組件的名稱:{{name}}</div>
        <div>A組件的名稱:{{NameForA}}</div>
    </div>
</template>

<script>
export default {
    data() {
        return {
            name:"yehaocong",
            NameForA:""
        }
    },
    methods:{
        //觸發(fā)事件時的回調函數
        getNameFromA(nameFromAVC){
            console.log("接收來自A組件的名稱:",nameFromAVC);
            this.NameForA = nameFromAVC;
        }
    },
    mounted() {
        //往事件總線總綁定自定義事件。
        this.$bus.$on("getNameFromA",this.getNameFromA);
    },
    beforeDestroy() {
        //通常在組件銷毀時,需要解綁自定義事件。
        this.$bus.$off("getNameFromA")
    },
}
</script>

<style>

</style>

在這里插入圖片描述

A.vue:

<template>
    <div>
        <div>{{name}}</div>
        <button @click="sendName">發(fā)送name屬性值到其他組件</button>
    </div>
</template>

<script>
export default {
    data() {
        return {
            name:"liaoxianyan"
        }
    },
    methods: {
        sendName(){
            //發(fā)送方觸發(fā)事件
            this.$bus.$emit("getNameFromA",this.name);
        }
    },
}
</script>

<style>

</style>

在這里插入圖片描述

效果:

在這里插入圖片描述

在這里插入圖片描述

通常最好需要在組件銷毀時解綁自定義事件:

在這里插入圖片描述

消息的發(fā)布訂閱

訂閱與發(fā)布的定義:

1.是一種組件間通信的一種方式。

類似有一個消息中心,組件A往該消息中心中訂閱了某消息,然后一旦消息組件B往該消息中發(fā)布該消息,組件A會立馬收到該消息,并執(zhí)行相應回調。

通常使用第三方的消息訂閱發(fā)布庫,這里推薦pubsub-js。

第一步:安裝該依賴:npm i pubsub-js

在這里插入圖片描述

第二步:在消息接收方進行訂閱消息。

第三步:在消息發(fā)送方進行消息的發(fā)布。

還是用上面的A、B組件作為例子,A組件時發(fā)送方,B組件時接收方。

第二步:

在B組件定義消息:

在這里插入圖片描述

第三步:在A組件發(fā)布消息:

在這里插入圖片描述

效果:

在這里插入圖片描述

在這里插入圖片描述

通常需要在組件銷毀時進行消息的取消訂閱。

在這里插入圖片描述

總結

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容! 

相關文章

  • vue通過element樹形控件實現(xiàn)樹形表格

    vue通過element樹形控件實現(xiàn)樹形表格

    這篇文章主要為大家介紹了vue?element樹形控件實現(xiàn)樹形表格,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • 詳解Vue.js 可拖放文本框組件的使用

    詳解Vue.js 可拖放文本框組件的使用

    這篇文章主要介紹了詳解Vue.js 可拖放文本框組件的相關資料,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下
    2021-03-03
  • 移動端Vue2.x Picker的全局調用實現(xiàn)

    移動端Vue2.x Picker的全局調用實現(xiàn)

    這篇文章主要介紹了移動端Vue2.x Picker的全局調用實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • vue項目常用組件和框架結構介紹

    vue項目常用組件和框架結構介紹

    這篇文章通過圖文形式給大家介紹了vue項目的骨架及常用組件的相關知識,對此有興趣的朋友跟著小編一起學習參考下吧。
    2017-12-12
  • Vue使用swiper問題(5.2.0版本,避免踩坑)

    Vue使用swiper問題(5.2.0版本,避免踩坑)

    這篇文章主要介紹了Vue使用swiper問題(5.2.0版本,避免踩坑),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Message組件實現(xiàn)發(fā)財UI?示例詳解

    Message組件實現(xiàn)發(fā)財UI?示例詳解

    這篇文章主要為大家介紹了Message組件實現(xiàn)發(fā)財UI的手寫示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • vue3+vite+ts父子組件之間的傳值

    vue3+vite+ts父子組件之間的傳值

    隨著vue2的落幕,vue3越來成熟,有必要更新一下vue3的父子組件之間的傳值方式,這里介紹下vue3+vite+ts父子組件之間的傳值方式實例詳解,感興趣的朋友一起看看吧
    2023-12-12
  • vue2.0在沒有dev-server.js下的本地數據配置方法

    vue2.0在沒有dev-server.js下的本地數據配置方法

    這篇文章主要介紹了vue2.0在沒有dev-server.js下的本地數據配置方法的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-02-02
  • Vue CLI項目 axios模塊前后端交互的使用(類似ajax提交)

    Vue CLI項目 axios模塊前后端交互的使用(類似ajax提交)

    這篇文章主要介紹了Vue-CLI項目-axios模塊前后端交互的使用詳解(類似ajax提交),本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-09-09
  • Vuex的store中的Module用法及說明

    Vuex的store中的Module用法及說明

    這篇文章主要介紹了Vuex的store中的Module用法及說明,具有很好的參考價值,希望對大家有所幫助。
    2023-01-01

最新評論