国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

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

瀏覽:115日期:2022-11-30 08:28:09

前言

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

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

$attrs

官方解釋:

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

我的理解:

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

圖解:

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

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

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

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

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

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

$listeners

官方解釋:

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

我的理解:

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

圖解:

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

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

{ customEvent: fn }

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

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

如果想要添加其他事件監(jiān)聽(tīng)器,可繼續(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ì)通過(guò)$attrs獲取到不在父親props里面的所有屬性,父親組件通過(guò)在孫子組件上綁定$attrs 和 $listeners 使孫組件獲取爺爺傳遞的值并且可以調(diào)用在爺爺那里定義的方法;

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

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

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 女人张开腿让男人捅的视频 | 特级毛片免费观看视频 | 日本美女视频韩国视频网站免费 | aa级毛片毛片免费观看久 | 国产一区二区三区亚洲综合 | 日韩一区国产二区欧美三区 | 偷自拍第一页 | 亚洲图片视频在线观看 | 日韩专区亚洲综合久久 | 久久久一本精品99久久精品66 | 亚洲视频在线免费播放 | 国产三a级日本三级日产三级 | 九九精品激情在线视频 | 一区二区三区四区五区六区 | 农村寡妇野外情一级毛片 | 亚洲日本va | 色综合久久88色综合天天小说 | 欧美日韩国产亚洲综合不卡 | 美女超爽久久久久网站 | 欧美成人手机在线 | 久久久久亚洲视频 | 欧美67194| 99久久精品免费看国产免费 | 性欧美欧美之巨大69 | 久久精品国产国产精品四凭 | 曰韩美女一级视频 | 91精品国产91久久久久久青草 | 久久伊人热| 91国在线视频| 久久免费视频在线观看30 | 日本在线视频免费看 | 亚洲一区二区三区高清视频 | 国产美女在线精品亚洲二区 | 欧美色视频日本片高清在线观看 | 成人毛片网站 | 中文字幕二区三区 | 99国产欧美久久精品 | 免费在线观看的毛片 | 国产精品日韩欧美在线 | 欧美日韩一区二区不卡三区 | 美女18一级毛片免费看 |