成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

Vue中$attrs和$listeners通信方式的實現(xiàn)原理是什么-創(chuàng)新互聯(lián)

這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)Vue中$attrs和$listeners通信方式的實現(xiàn)原理是什么,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

創(chuàng)新互聯(lián)專注于棗莊企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站設(shè)計,商城網(wǎng)站開發(fā)。棗莊網(wǎng)站建設(shè)公司,為棗莊等地區(qū)提供建站服務(wù)。全流程按需網(wǎng)站制作,專業(yè)設(shè)計,全程項目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)

前言

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

Vue中$attrs和$listeners通信方式的實現(xiàn)原理是什么

$attrs

官方解釋:

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

我的理解:

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

圖解:

Vue中$attrs和$listeners通信方式的實現(xiàn)原理是什么

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

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

Vue中$attrs和$listeners通信方式的實現(xiàn)原理是什么

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

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

$listeners

官方解釋:

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

我的理解:

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

圖解:

Vue中$attrs和$listeners通信方式的實現(xiàn)原理是什么

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

{ customEvent: fn }

Vue中$attrs和$listeners通信方式的實現(xiàn)原理是什么

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

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

使用場景:

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

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

上述就是小編為大家分享的Vue中$attrs和$listeners通信方式的實現(xiàn)原理是什么了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道。

文章標(biāo)題:Vue中$attrs和$listeners通信方式的實現(xiàn)原理是什么-創(chuàng)新互聯(lián)
本文來源:http://jinyejixie.com/article10/jihdo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機、建站公司、做網(wǎng)站域名注冊、企業(yè)網(wǎng)站制作、網(wǎng)站設(shè)計

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司
古交市| 横峰县| 灌阳县| 涟水县| 尉氏县| 双鸭山市| 虎林市| 东丰县| 邯郸县| 城步| 宜城市| 稷山县| 桂东县| 台中县| 襄城县| 神木县| 四子王旗| 铜川市| 宿州市| 视频| 江阴市| 清丰县| 剑阁县| 错那县| 昌江| 宝坻区| 神农架林区| 山西省| 常熟市| 尚义县| 阿鲁科尔沁旗| 西充县| 兴文县| 洛宁县| 于都县| 鹿邑县| 万安县| 金湖县| 正宁县| 景德镇市| 塔河县|