vue的插槽原來該這樣理解
一、認識插槽Slot
前面我們會通過props傳遞給組件一些數(shù)據(jù),讓組件來進行展示,但是為了讓這個組件具備更強的通用性,我們不能將組件中的內(nèi)容限制為固定的div、span等等這些元素,比如某種情況下我們使用組件,希望組件顯示的是一個按鈕,某種情況下我們使用組件希望顯示的是一張圖片,我們應(yīng)該讓使用者可以決定某一塊區(qū)域到底存放什么內(nèi)容和元素。所以有了插槽的存在,我們可以提高組件的復用性,并且也提高組件的靈活性。
二、插槽的基本使用
直接在其中使用<slot></slot>
三、插槽的默認內(nèi)容
如果想要設(shè)置插槽的默認內(nèi)容,可以直接在<slot></slot>
標簽內(nèi)添加內(nèi)容。
四、多個插槽實現(xiàn)的效果
如上圖所示,如果在組件之間設(shè)置多個標簽,則會在該組件的每一個插槽中都添加多個標簽。
如上面代碼所示:在組件中的每一個<slot></slot>
中使用name
屬性設(shè)置插槽名,并且組件中間使用template
標簽并且設(shè)置v-slot:屬性名
來進行一一對應(yīng)。
五、動態(tài)插槽
有時候我們的插槽名稱不固定,需要從外界傳入,這是就需要使用動態(tài)插槽。
如上圖所示,我們在<slot></slot>
中動態(tài)綁定屬性名,該屬性為通過props傳入的,我們在外部,通過v-slot:[na]
來動態(tài)綁定屬性。
六、具名插槽的縮寫
如上圖所示,具名插槽的v-slot:left
可以縮寫為#left
。
七、渲染作用域
父級模板的所有內(nèi)容在父級模板中編譯。 子級模板的所有內(nèi)容在子集模板中進行編譯。
如圖所示,父組件中存在title,子組件中也存在title,但是最終顯示的是父組件的title屬性。
八、作用域插槽的案例
這里在父組件中的data
中設(shè)置數(shù)組數(shù)據(jù),并將其通過props
傳遞給組件內(nèi)部,子組件拿到數(shù)組后,通過for
循環(huán)遍歷數(shù)組中的每一項內(nèi)容,并且將數(shù)據(jù)通過v-bind
綁定到slot
標簽上,然后在父組件可以通過v-slot:default="data"
,這個data
變量就是數(shù)據(jù)。
九、獨占默認插槽縮寫
上面是作用域插槽的完整寫法
下面可以將其改寫為:
也可以改寫為:
十、默認插槽和具名的混合
作用域插槽案例可以改寫為:
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
vue3.0 CLI - 1 - npm 安裝與初始化的入門教程
這篇文章主要介紹了vue3.0 CLI - 1 - npm 安裝與初始化的入門教程,本文通過實例代碼相結(jié)合的形式,給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2018-09-09詳解如何使用Vue-PDF在應(yīng)用中嵌入PDF文檔
在現(xiàn)代Web應(yīng)用中,PDF文檔的使用非常普遍,因為它可以在各種設(shè)備和操作系統(tǒng)上保持一致的外觀和格式,本文我們就來探討一下如何在Vue.js應(yīng)用中使用vue-pdf庫嵌入PDF文檔吧2023-08-08Vue3 構(gòu)建 Web Components使用詳解
這篇文章主要為大家介紹了Vue3 構(gòu)建 Web Components使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09electron?vue?模仿qq登錄界面功能實現(xiàn)
這篇文章主要介紹了electron?vue?模仿qq登錄界面,首先使用vuecli創(chuàng)建vue項目,安裝electron,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08