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

Vue組件通信$attrs、$listeners實(shí)現(xiàn)原理解析

 更新時(shí)間:2020年09月03日 10:34:48   作者:返回主頁WahFung  
這篇文章主要介紹了Vue組件通信$attrs、$listeners實(shí)現(xiàn)原理解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

前言

vue通信手段有很多種,props/emit、vuex、event bus、provide/inject 等。還有一種通信方式,那就是$attrs和$listeners,之前早就聽說這兩個(gè)api,趁著有空來補(bǔ)補(bǔ)。這種方式挺優(yōu)雅,使用起來也不賴。下面例子都會(huì)通過父、子、孫子,三者的關(guān)系來說明使用方式。

$attrs

官方解釋:

包含了父作用域中不作為 prop 被識(shí)別 (且獲取) 的特性綁定 (class和style除外)。當(dāng)一個(gè)組件沒有聲明任何 prop 時(shí),這里會(huì)包含所有父作用域的綁定 (class和style除外),并且可以通過v-bind="$attrs"傳入內(nèi)部組件——在創(chuàng)建高級(jí)別的組件時(shí)非常有用。

我的理解:

接收除了props聲明外的所有綁定屬性(class、style除外)

圖解:

由于child.vue 在 props 中聲明了 name 屬性,$attrs 中只有age、gender兩個(gè)屬性,輸出結(jié)果為:

{age: "20",gender: "man"}

另外可以在 grandson.vue 上通過 v-bind="$attrs", 可以將屬性繼續(xù)向下傳遞,讓 grandson.vue 也能訪問到父組件的屬性,這在傳遞多個(gè)屬性時(shí)會(huì)顯得很便捷,而不用一條條的進(jìn)行綁定。

如果想要添加其他屬性,可繼續(xù)綁定屬性。但要注意的是,繼續(xù)綁定的屬性和 $attrs 中的屬性有重復(fù)時(shí),繼續(xù)綁定的屬性優(yōu)先級(jí)會(huì)更高。

$listeners

官方解釋:

包含了父作用域中的 (不含.native修飾器的)v-on事件監(jiān)聽器。它可以通過v-on="$listeners"傳入內(nèi)部組件——在創(chuàng)建更高層次的組件時(shí)非常有用。

我的理解:

接收除了帶有.native事件修飾符的所有事件監(jiān)聽器

圖解:

parent.vue中對(duì) child.vue 綁定了兩個(gè)事件,帶有.native的 click 事件和一個(gè)自定義事件,所以在 child.vue 中,輸出$listeners的結(jié)果為:

{ customEvent: fn }

同 attrs 屬性一樣,可以通過 v-on="$listeners",將事件監(jiān)聽器繼續(xù)向下傳遞,讓 grandson.vue 訪問到事件,且可以使用 $emit 觸發(fā) parent.vue 的函數(shù)。

如果想要添加其他事件監(jiān)聽器,可繼續(xù)綁定事件。但要注意的是,繼續(xù)綁定的事件和 $listeners 中的事件有重復(fù)時(shí),不會(huì)被覆蓋。當(dāng) grandson.vue 觸發(fā) customEvent 時(shí),child.vue 和 parent.vue 的事件都會(huì)被觸發(fā),觸發(fā)順序類似于冒泡,先到 child.vue 再到 parent.vue。

使用場(chǎng)景:

組件傳值時(shí)使用: 爺爺在父親組件傳遞值,父親組件會(huì)通過$attrs獲取到不在父親props里面的所有屬性,父親組件通過在孫子組件上綁定$attrs 和 $listeners 使孫組件獲取爺爺傳遞的值并且可以調(diào)用在爺爺那里定義的方法;

對(duì)一些UI庫進(jìn)行二次封裝時(shí)使用:比如element-ui,里面的組件不能滿足自己的使用場(chǎng)景的時(shí)候,會(huì)二次封裝,但是又想保留他自己的屬性和方法,那么這個(gè)時(shí)候時(shí)候$attrs和$listners是個(gè)完美的解決方案。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • element中的el-upload附件上傳與附件回顯

    element中的el-upload附件上傳與附件回顯

    這篇文章主要介紹了element中的el-upload附件上傳與附件回顯方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue使用echarts詞云圖的實(shí)戰(zhàn)記錄

    vue使用echarts詞云圖的實(shí)戰(zhàn)記錄

    這篇文章主要給大家介紹了關(guān)于vue使用echarts詞云圖的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • vue使用動(dòng)畫實(shí)現(xiàn)滾動(dòng)表格效果

    vue使用動(dòng)畫實(shí)現(xiàn)滾動(dòng)表格效果

    這篇文章主要為大家詳細(xì)介紹了vue使用動(dòng)畫實(shí)現(xiàn)滾動(dòng)表格效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 前端vue?a鏈接下載文件失敗的問題(未發(fā)現(xiàn)文件)

    前端vue?a鏈接下載文件失敗的問題(未發(fā)現(xiàn)文件)

    這篇文章主要介紹了前端vue?a鏈接下載文件失敗的問題(未發(fā)現(xiàn)文件),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue3解決跨域問題詳細(xì)代碼親測(cè)有效

    vue3解決跨域問題詳細(xì)代碼親測(cè)有效

    跨域,跨的是不同域,也就是協(xié)議或主機(jī)或或端口號(hào)不同造成的現(xiàn)象,本文給大家分享vue3解決跨域問題詳細(xì)代碼親測(cè)有效,感興趣的朋友跟隨小編一起看看吧
    2022-11-11
  • vue3.0實(shí)現(xiàn)復(fù)選框組件的封裝

    vue3.0實(shí)現(xiàn)復(fù)選框組件的封裝

    這篇文章主要為大家詳細(xì)介紹了vue3.0實(shí)現(xiàn)復(fù)選框組件的封裝代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 在vue中使用v-bind:class的選項(xiàng)卡方法

    在vue中使用v-bind:class的選項(xiàng)卡方法

    今天小編就為大家分享一篇在vue中使用v-bind:class的選項(xiàng)卡方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vuex管理狀態(tài)倉(cāng)庫使用詳解

    vuex管理狀態(tài)倉(cāng)庫使用詳解

    這篇文章主要介紹了vuex管理狀態(tài)倉(cāng)庫使用詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Vue?+?Element?自定義上傳封面組件功能

    Vue?+?Element?自定義上傳封面組件功能

    這篇文章主要介紹了Vue?+?Element?自定義上傳封面組件,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-01-01
  • vue使用recorder-core.js實(shí)現(xiàn)錄音功能

    vue使用recorder-core.js實(shí)現(xiàn)錄音功能

    這篇文章主要介紹了vue如何使用recorder-core.js實(shí)現(xiàn)錄音功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07

最新評(píng)論