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

Vue非父子組件之間的通信方式詳解

 更新時(shí)間:2022年07月28日 15:36:32   作者:林有酒  
在實(shí)際業(yè)務(wù)中,除了父子組件通信外,還有很多非父子組件通信的場(chǎng)景,下面這篇文章主要給大家介紹了關(guān)于Vue非父子組件之間的通信方式,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

非父子組件的通信

此篇講解的是, 在學(xué)習(xí)狀態(tài)管理之前, 非父子間通信的方案

在開(kāi)發(fā)中,我們構(gòu)建了組件樹(shù)之后,除了父子組件之間的通信之外,還會(huì)有非父子組件之間的通信。

這里我們主要講兩種方式

  • Provide/Inject;
  • 全局事件總線;

1.Provide和Inject

1.1基本使用

Provide/Inject用于非父子組件之間共享數(shù)據(jù)

  • 比如有一些深度嵌套的組件,子組件想要獲取父組件的部分內(nèi)容;
  • 在這種情況下,如果我們?nèi)匀粚rops沿著組件鏈逐級(jí)傳遞下去,就會(huì)非常的麻煩;

對(duì)于這種情況下,我們可以使用 Provide 和 Inject

  • 無(wú)論層級(jí)結(jié)構(gòu)有多深,父組件都可以作為其所有子組件的依賴提供者;
  • 父組件有一個(gè) provide 選項(xiàng)來(lái)提供數(shù)據(jù);
  • 子組件有一個(gè) inject 選項(xiàng)來(lái)開(kāi)始使用這些數(shù)據(jù);

實(shí)際上,你可以將依賴注入看作是“long range props”,除了

  • 父組件不需要知道哪些子組件使用它 provide 的 property
  • 子組件不需要知道 inject 的 property 來(lái)自哪里

我們開(kāi)發(fā)一個(gè)下面這樣的結(jié)構(gòu): 讓App.vue提供一些數(shù)據(jù)給HomeContent.vue使用[外鏈圖片轉(zhuǎn)存失敗,

在祖先組件中通過(guò)provide將數(shù)據(jù)傳出, provide對(duì)應(yīng)的是一個(gè)對(duì)象

export default {
  components: {
    Home
  },
  // 通過(guò)provide將數(shù)據(jù)傳出
	provide() {
		return {
			name: this.name,
			age: this.age,
			height: this.height
		}
	}
}

在后代元素中, 通過(guò)inject接收祖先傳遞的數(shù)據(jù), inject對(duì)應(yīng)的是一個(gè)數(shù)組

export default {
  inject: ["name", "age", "height"]
}

1.2處理響應(yīng)式數(shù)據(jù)(了解)

我們先來(lái)驗(yàn)證一個(gè)結(jié)果:如果我們修改了this.names的內(nèi)容,那么使用length的子組件會(huì)不會(huì)是響應(yīng)式的?

<template>
  <div class="app">
    <home />
    <h2>{{ name }}</h2>
    <button @click="btnClick">按鈕</button>
  </div>
</template>

<script>
  import Home from './Home.vue'

  export default {
    components: {
      Home
    },
    data() {
      return {
        name: "chenyq",
        age: 18,
        height: 1.88,
      }
    },
    // 通過(guò)provide將數(shù)據(jù)傳出
    provide() {
      return {
        name: this.name,
        age: this.age,
        height: this.height
      }
    },
    methods: {
      btnClick() {
        this.name = "kaisa"
      }
    },
  }
</script>

我們會(huì)發(fā)現(xiàn)對(duì)應(yīng)的子組件中是沒(méi)有反應(yīng)的

這是因?yàn)楫?dāng)我們修改了names之后,之前在provide中引入的 this.name 本身并不是響應(yīng)式的;

那么怎么樣可以讓我們的數(shù)據(jù)變成響應(yīng)式的呢?

  • 非常的簡(jiǎn)單,我們可以使用響應(yīng)式的一些API來(lái)完成這些功能,比如說(shuō)computed函數(shù);
  • 當(dāng)然,這個(gè)computed是vue3的新特性,在后面我會(huì)專門講解,這里大家可以先直接使用一下;
import { computed } from 'vue'

export default {
  components: {
    Home
  },
  data() {
    return {
      name: "chenyq",
      age: 18,
      height: 1.88,
    }
  },
  // 通過(guò)provide將數(shù)據(jù)傳出
  provide() {
    return {
      name: computed(() => this.name),
      age: this.age,
      height: this.name
    }
  },
  methods: {
    btnClick() {
      this.name = "kaisa"
    }
  },
}

注意:我們?cè)谑褂胣ame的時(shí)候需要獲取其中的value

這是因?yàn)閏omputed返回的是一個(gè)ref對(duì)象,需要取出其中的value來(lái)使用;

<template>
  <div class="home-content">
    <h2>名字: {{ name.value }}, 年齡: {{ age}}, 身高: {{ height}}</h2>
  </div>
</template>

2.全局事件總線

Vue3從實(shí)例中移除了 o n 、 on、 on、off 和 $once 方法,所以我們?nèi)绻M^續(xù)使用全局事件總線,要通過(guò)第三方的庫(kù)

  • Vue3官方有推薦一些庫(kù),例如 mitt 或 tiny-emitter, 這兩個(gè)庫(kù)雖然不再維護(hù), 但還是可以使用的;
  • 這里我們主要講解一下 hy-event-store 的使用, 是前端大神coderwhy封裝的他自己的庫(kù);

首先,我們需要先安裝這個(gè)庫(kù)npm install hy-event-store

其次,我們可以封裝一個(gè)工具eventbus.js

import { HyEventBus } from "hy-event-store";
const eventBus = new HyEventBus()
export default eventBus

在項(xiàng)目中導(dǎo)入后可以使用它們

  • 我們?cè)贏pp.vue中監(jiān)聽(tīng)事件;
  • 我們?cè)贐anner.vue中觸發(fā)事件;

Banner中觸發(fā)事件:

<template>
  <div class="home-content">
    <button @click="btnClick">按鈕</button>
  </div>
</template>

<script>
  import eventBus from './utils/event-bus'

  export default {
    methods: {
      btnClick() {
        console.log("myEvent事件被監(jiān)聽(tīng)")
				// 發(fā)送事件到事件總線上
        eventBus.emit("myEvent", "chenyq", 18, 1.88)
      }
    },
  }
</script>

App中監(jiān)聽(tīng)事件:

<script>
  import eventBus from './utils/event-bus'
  import Home from './Home.vue'

  export default {
    components: {
      Home
    },
    created() {
			// 監(jiān)聽(tīng)事件總線上的事件
      eventBus.on("myEvent", (name, age, height) => {
        console.log(name, age, height)
      })
    },
  }
</script>

總結(jié)

到此這篇關(guān)于Vue非父子組件之間的通信方式的文章就介紹到這了,更多相關(guān)Vue非父子組件通信內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue.js常用指令之循環(huán)使用v-for指令教程

    Vue.js常用指令之循環(huán)使用v-for指令教程

    這篇文章主要跟大家介紹了關(guān)于Vue.js常用指令之循環(huán)使用v-for指令的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-06-06
  • Vue2 cube-ui時(shí)間選擇器詳解

    Vue2 cube-ui時(shí)間選擇器詳解

    這篇文章主要為大家介紹了Vue2 cube-ui時(shí)間選擇器,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2021-12-12
  • vue的基本用法與常見(jiàn)指令

    vue的基本用法與常見(jiàn)指令

    Vue.js是JavaScript MVVM(Model-View-ViewModel)庫(kù),十分簡(jiǎn)潔,Vue核心只關(guān)注視圖層,相對(duì)AngularJS提供更加簡(jiǎn)潔、易于理解的API。接下來(lái)通過(guò)本文給大家介紹vue的基本用法與常見(jiàn)指令,感興趣的朋友一起看看吧
    2017-08-08
  • form?表單驗(yàn)證是異步問(wèn)題記錄(推薦)

    form?表單驗(yàn)證是異步問(wèn)題記錄(推薦)

    這篇文章主要介紹了form?表單驗(yàn)證是異步問(wèn)題記錄,通過(guò)實(shí)例代碼介紹了Promise.all 和 Promise.allSettled 區(qū)別,需要的朋友可以參考下
    2023-01-01
  • Vue中錯(cuò)誤圖片的處理的實(shí)現(xiàn)代碼

    Vue中錯(cuò)誤圖片的處理的實(shí)現(xiàn)代碼

    這篇文章主要介紹了Vue中錯(cuò)誤圖片的處理的實(shí)現(xiàn)代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • vue2和elementUI?實(shí)現(xiàn)落日余暉登錄頁(yè)和滑塊校驗(yàn)功能

    vue2和elementUI?實(shí)現(xiàn)落日余暉登錄頁(yè)和滑塊校驗(yàn)功能

    這篇文章主要介紹了vue2和elementUI打造落日余暉登錄頁(yè)和滑塊校驗(yàn),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • Vue通過(guò)for循環(huán)隨機(jī)生成不同的顏色或隨機(jī)數(shù)的實(shí)例

    Vue通過(guò)for循環(huán)隨機(jī)生成不同的顏色或隨機(jī)數(shù)的實(shí)例

    今天小編就為大家分享一篇Vue通過(guò)for循環(huán)隨機(jī)生成不同的顏色或隨機(jī)數(shù)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-11-11
  • Vue2?響應(yīng)式系統(tǒng)之異步隊(duì)列

    Vue2?響應(yīng)式系統(tǒng)之異步隊(duì)列

    這篇文章主要介紹了Vue2?響應(yīng)式系統(tǒng)之異步隊(duì)列,文章基于Vue2?的相關(guān)資料展開(kāi)對(duì)主題的詳細(xì)介紹,具有一定的參考價(jià)值需要的小伙伴可以參考一下
    2022-04-04
  • vue2.x雙向數(shù)據(jù)綁定原理解析

    vue2.x雙向數(shù)據(jù)綁定原理解析

    雙向數(shù)據(jù)綁定原理主要運(yùn)用了發(fā)布訂閱模式來(lái)實(shí)現(xiàn)的,通過(guò)Object.defineProperty對(duì)數(shù)據(jù)劫持,觸發(fā)getter,setter方法,這篇文章主要介紹了vue2.x雙向數(shù)據(jù)綁定原理,需要的朋友可以參考下
    2023-02-02
  • vue 實(shí)現(xiàn)把路由單獨(dú)分離出來(lái)

    vue 實(shí)現(xiàn)把路由單獨(dú)分離出來(lái)

    這篇文章主要介紹了vue 實(shí)現(xiàn)把路由單獨(dú)分離出來(lái),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08

最新評(píng)論