Vue中的api傳值可以在組件之間進行數據傳遞,實現組件的復用和互相配合。Vue提供了一系列的api用于實現數據傳遞,包括props、$emit、$parent、$children、$attrs、$listeners等等。
其中props是最常用的api之一,它用于在父組件和子組件之間傳遞數據。父組件可以像子組件傳遞數據,而子組件也可以通過props接收父組件傳遞過來的數據。在子組件中需要定義props來接收數據,定義格式如下:
props: { propA: { type: String, default: 'default value' } }
其中propA是props對象中的屬性,type指定了傳遞的數據類型,default設定了默認值。在父組件中傳遞數據的語法如下:
其中prop-a就是子組件定義的propA屬性,它的值為"value"。
另一個常用的api是$emit,它可以用于在子組件中觸發父組件的事件。在子組件中,可以使用this.$emit觸發事件,語法如下:
this.$emit('eventName', data)
其中eventName為事件名稱,data是需要傳遞給父組件的數據。
在父組件中需要監聽子組件的事件,語法如下:
其中@event-name表示監聽子組件的eventName事件,methodName為觸發事件后需要執行的方法名稱。
除了props和$emit,Vue還提供了一些其他的api用于組件之間的數據傳遞。$parent可以訪問當前組件的父組件實例,$children可以訪問當前組件的子組件實例數組。$attrs可以獲取父組件傳遞給子組件但在子組件中未聲明的屬性,$listeners可以獲取父組件綁定在子組件上但在子組件中未聲明的事件。
總之,Vue的api傳值非常強大,可以實現組件之間的數據傳遞和事件觸發。在開發中,需要根據實際情況來選擇最適合的api,以提高組件之間的協作效率。