Vue中插槽slot的使用方法與應用場景詳析

什麼是插槽?

我們知道在Vue中 Child 組件的標簽 的中間是不可以包著什麼的 。

可是往往在很多時候我們在使用組件的時候總想在組件間外面自定義一些標簽,vue新增瞭一種插槽機制,叫做作用域插槽。要求的版本是2.1.0+;

插槽,其實就相當於占位符。它在組件中給你的HTML模板占瞭一個位置,讓你來傳入一些東西。插槽又分為 匿名插槽、具名插槽、作用域插槽。

在 2.6.0 中,我們為具名插槽和作用域插槽引入瞭一個新的統一的語法 (即 v-slot 指令)。它取代瞭 slot 和 slot-scope

匿名插槽

匿名插槽,我們也可以叫它單個插槽或者默認插槽。和具名插槽相對,它是不需要設置 name 屬性的,它隱藏的name屬性為default。

father.vue

child.vue

匿名插槽,name的屬性對應的是 default 也可以不寫就是默認的意思啦;

在使用的時候還有一個問題要註意的 如果是有2個以上的匿名插槽是會child標簽裡面的內容全部都替換到每個slot;

具名插槽 (vue2.6.0+被廢棄的slot=’name’)

顧名思義就是slot 是帶有name的 ,定義:  或者使用簡單縮寫的定義 #header 使用:要用一個 template標簽包裹

father.vue

child.vue

這裡說一下多個具名插槽的使用 多個具名插槽,插槽的位置不是使用插槽的位置而定的,是在定義的時候的位置來替換的

father.vue

child.vue

作用域插槽

就是用來傳遞數據的插槽

當你想在一個插槽中使用數據時,要註意一個問題作用域的問題,Vue 官方文檔中說瞭父級模板裡的所有內容都是在父級作用域中編譯的;子模板裡的所有內容都是在子作用域中編譯的;

為瞭讓 子組件中的數據 在父級的插槽 內容中可用我們可以將 數據 作為 元素的一個特性綁定上去: v-bind:text=”text”

註意:

匿名的作用域插槽和具名的作用域插槽 區別在v-slot:defult=”接受的名稱”(defult(匿名的可以不寫,具名的相反要寫的是對應的name))

v-solt可以解構接收 解構接收的字段要和傳的字段一樣才可以 例如 :one 對應 v-slot=”{one}”

效果圖

總結

到此這篇關於Vue中插槽slot的使用方法與應用場景的文章就介紹到這瞭,更多相關Vue插槽slot用法內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: