vue的插槽原來該這樣理解
一、認(rèn)識(shí)插槽Slot
前面我們會(huì)通過props傳遞給組件一些數(shù)據(jù),讓組件來進(jìn)行展示,但是為了讓這個(gè)組件具備更強(qiáng)的通用性,我們不能將組件中的內(nèi)容限制為固定的div、span等等這些元素,比如某種情況下我們使用組件,希望組件顯示的是一個(gè)按鈕,某種情況下我們使用組件希望顯示的是一張圖片,我們應(yīng)該讓使用者可以決定某一塊區(qū)域到底存放什么內(nèi)容和元素。所以有了插槽的存在,我們可以提高組件的復(fù)用性,并且也提高組件的靈活性。
二、插槽的基本使用
直接在其中使用<slot></slot>


三、插槽的默認(rèn)內(nèi)容


如果想要設(shè)置插槽的默認(rèn)內(nèi)容,可以直接在<slot></slot>標(biāo)簽內(nèi)添加內(nèi)容。
四、多個(gè)插槽實(shí)現(xiàn)的效果



如上圖所示,如果在組件之間設(shè)置多個(gè)標(biāo)簽,則會(huì)在該組件的每一個(gè)插槽中都添加多個(gè)標(biāo)簽。


如上面代碼所示:在組件中的每一個(gè)<slot></slot>中使用name屬性設(shè)置插槽名,并且組件中間使用template標(biāo)簽并且設(shè)置v-slot:屬性名來進(jìn)行一一對(duì)應(yīng)。

五、動(dòng)態(tài)插槽
有時(shí)候我們的插槽名稱不固定,需要從外界傳入,這是就需要使用動(dòng)態(tài)插槽。


如上圖所示,我們?cè)?code><slot></slot>中動(dòng)態(tài)綁定屬性名,該屬性為通過props傳入的,我們?cè)谕獠浚ㄟ^v-slot:[na]來動(dòng)態(tài)綁定屬性。
六、具名插槽的縮寫

如上圖所示,具名插槽的v-slot:left可以縮寫為#left。
七、渲染作用域
父級(jí)模板的所有內(nèi)容在父級(jí)模板中編譯。 子級(jí)模板的所有內(nèi)容在子集模板中進(jìn)行編譯。



如圖所示,父組件中存在title,子組件中也存在title,但是最終顯示的是父組件的title屬性。
八、作用域插槽的案例

這里在父組件中的data中設(shè)置數(shù)組數(shù)據(jù),并將其通過props傳遞給組件內(nèi)部,子組件拿到數(shù)組后,通過for循環(huán)遍歷數(shù)組中的每一項(xiàng)內(nèi)容,并且將數(shù)據(jù)通過v-bind綁定到slot標(biāo)簽上,然后在父組件可以通過v-slot:default="data",這個(gè)data變量就是數(shù)據(jù)。
九、獨(dú)占默認(rèn)插槽縮寫


上面是作用域插槽的完整寫法
下面可以將其改寫為:

也可以改寫為:

十、默認(rèn)插槽和具名的混合
作用域插槽案例可以改寫為:

總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
vue 通過base64實(shí)現(xiàn)圖片下載功能
這篇文章主要介紹了vue 通過base64實(shí)現(xiàn)圖片下載功能,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下2020-12-12
基于Vue實(shí)現(xiàn)的多條件篩選功能的詳解(類似京東和淘寶功能)
這篇文章主要介紹了Vue多條件篩選功能,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
vue3中el-table實(shí)現(xiàn)表格合計(jì)行的示例代碼
這篇文章主要介紹了vue3中el-table實(shí)現(xiàn)表格合計(jì)行,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-01-01
vue 實(shí)現(xiàn)超長(zhǎng)文本截取,懸浮框提示
這篇文章主要介紹了vue 實(shí)現(xiàn)超長(zhǎng)文本截取,懸浮框提示,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07
vue語(yǔ)法之render函數(shù)和jsx的基本使用
這篇文章主要介紹了vue語(yǔ)法之render函數(shù)和jsx的基本使用,在Vue中是支持jsx的,凡是我們是比較少在Vue中使用jsx的,jsx在react中使用的更加廣泛,因此在這里我簡(jiǎn)單介紹一下jsx的基本使用,需要的朋友可以參考下2022-08-08
vue使用keep-alive實(shí)現(xiàn)組件切換時(shí)保存原組件數(shù)據(jù)方法
這篇文章主要介紹了vue使用keep-alive實(shí)現(xiàn)組件切換時(shí)保存原組件數(shù)據(jù)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-10-10
vue實(shí)現(xiàn)對(duì)highlight-current-row方式整行選中后修改默認(rèn)背景顏色
這篇文章主要介紹了vue實(shí)現(xiàn)對(duì)highlight-current-row方式整行選中后修改默認(rèn)背景顏色方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11

