1. 程式人生 > 實用技巧 >【Vue】 元件通訊之$attrs、$listeners

【Vue】 元件通訊之$attrs、$listeners

前言

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

$attrs

官方解釋:

包含了父作用域中不作為 prop 被識別 (且獲取) 的特性繫結 (classstyle除外)。當一個元件沒有宣告任何 prop 時,這裡會包含所有父作用域的繫結 (classstyle除外),並且可以通過v-bind="$attrs"傳入內部元件——在建立高級別的元件時非常有用。

我的理解:

接收除了props宣告外的所有繫結屬性(class、style除外)

圖解:

由於child.vue 在 props 中聲明瞭 name 屬性,$attrs 中只有age、gender兩個屬性,輸出結果為:

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

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

如果想要新增其他屬性,可繼續繫結屬性。但要注意的是,繼續繫結的屬性和 $attrs 中的屬性有重複時,繼續繫結的屬性優先順序會更高。

$listeners

官方解釋:

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

我的理解:

接收除了帶有.native事件修飾符的所有事件監聽器

圖解:

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

{ customEvent: fn }

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

如果想要新增其他事件監聽器,可繼續繫結事件。但要注意的是,繼續繫結的事件和 $listeners 中的事件有重複時,不會被覆蓋。當 grandson.vue 觸發 customEvent 時,child.vue 和 parent.vue 的事件都會被觸發,觸發順序類似於冒泡,先到 child.vue 再到 parent.vue。

使用場景:

  1. 元件傳值時使用: 爺爺在父親元件傳遞值,父親元件會通過$attrs獲取到不在父親props裡面的所有屬性,父親元件通過在孫子元件上繫結$attrs 和 $listeners 使孫元件獲取爺爺傳遞的值並且可以呼叫在爺爺那裡定義的方法;

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

轉自:https://www.cnblogs.com/chanwahfung/p/11520909.html