Vue 2.5 中的 slot scope 為我們提供了更加靈活的跨組件數(shù)據(jù)傳遞方式。slot scope 允許父組件向子組件傳遞變量和方法,在子組件中使用父組件傳遞的變量和方法。這樣做可以減少跨組件傳遞數(shù)據(jù)時(shí)需要使用 Vuex 或 EventBus 等框架的情況,并且也不需要讓子組件對(duì)數(shù)據(jù)進(jìn)行繁瑣的父子組件傳遞。
slot scope 使用場(chǎng)景是父組件引用子組件并賦值,通過(guò)后代組件使用父組件的值。使用 slot scope 最好是遵循“組件化”的設(shè)計(jì)思路,在編寫(xiě)實(shí)際項(xiàng)目時(shí)具體場(chǎng)景具體分析。
下面我們來(lái)簡(jiǎn)單介紹一下 slot scope 基本用法和注意事項(xiàng)。
第一步,在父組件中定義要傳遞的數(shù)據(jù)及方法。具體操作是通過(guò)在標(biāo)簽上定義 slot-scope 屬性,將要傳遞的數(shù)據(jù)和方法賦值給該屬性。比如:標(biāo)簽上使用 slot-scope 屬性來(lái)進(jìn)行定義,而子組件則需要在標(biāo)簽上使用 v-slot 屬性來(lái)進(jìn)行定義。同時(shí),子組件中的 $slots 對(duì)象上,可以通過(guò)給定的 slot 名稱(chēng)來(lái)獲取到具體的 slot。而子組件中通過(guò)調(diào)用 $scopedSlots 對(duì)象來(lái)獲取到所有的 slot 信息。
<template v-slot:default="slotProps">
{{ slotProps.name }}
</template>
在這段代碼中,我們定義了一個(gè)供子組件使用的默認(rèn) slot,并定義了一個(gè) slotProps 變量來(lái)接收父組件傳遞過(guò)來(lái)的數(shù)據(jù)及方法。那么在這里,我們就假設(shè)父組件中有一個(gè)名字為 name 的變量需要傳遞給子組件使用。
第二步,在子組件中使用父組件傳遞過(guò)來(lái)的數(shù)據(jù)。具體操作是在子組件中通過(guò) $slots 對(duì)象獲取到具有父組件傳遞過(guò)來(lái)數(shù)據(jù)的 slot 中的數(shù)據(jù),然后將父組件傳遞過(guò)來(lái)的數(shù)據(jù)展示在子組件中。比如:<template>
<div>
<my-component>
<template v-slot:default="slotProps">
{{ slotProps.name }}
</template>
</my-component>
</div>
</template>
在這段代碼中,我們定義了一個(gè)自定義組件 my-component,然后在自定義組件中引用了我們?cè)诟附M件中定義的 slot。在子組件 my-component 的模板中,我們使用了 slotProps.name 這個(gè)變量展示了父組件傳遞過(guò)來(lái)的 name 變量。
最后需要注意的是,在使用 slot scope 時(shí),父組件需要在