2023 Vue直播班筆記 - Slot插槽

更新於 發佈於 閱讀時間約 6 分鐘
筆記以個人清楚理解方式記錄

前言

插槽是甚麼?插槽是父元件針對子元件內的某區塊根據不同需求提供不同樣板渲染的功能,也可以說是父元件對於子元件內該區塊的延伸應用,其中包含

  • 具名
  • 默認預設


以下以簡單的圖例說明:

默認插槽

<div id="app">
<h3>Slot 插巢與插巢預設值</h3>
<card></card>
<br>
<card></card>
</div>

<script type="module">
const app = Vue.createApp({});
app.component('card', {
template: `
<div class="card" style="width: 18rem;">
<div class="card-header">
元件 Header
</div>
<div class="card-body">
<p>這段是預設的文字</p>
</div>
<div class="card-footer">
元件 Footer
</div>
</div>`
})
app.mount('#app');
</script>
raw-image


這時我們如果想把card內某個區塊釋放出來要怎麼做呢?

這邊以<p>這段是預設的文字</p> 來展示,把它釋放後會變成

app.component('card', {
template: `
<div class="card" style="width: 18rem;">
<div class="card-header">
元件 Header
</div>
<div class="card-body">
<slot></slot>
</div>
<div class="card-footer">
元件 Footer
</div>
</div>`
})
raw-image


子元件釋放出了空間,我們便可以加以應用它,

因此我們可以在父元件放入自己寫的HTML,

如果外層有定義會先優先引用外層定義的HTML,

沒有則會引用子元件自己本身<slot></slot>內的HTML

<div id="app">
<h3>Slot 插巢與插巢預設值</h3>
<card>
<p>我是父元件定義的</p>
</card>
<br>
<card></card>
</div>
raw-image


由於未具名,所以這是屬於插槽默認的預設值插槽行為,

但是如果有需求要指定各部位顯示的話呢?


具名插槽 / 具名插槽縮寫

我們先準備第二組範例card2

<div id="app">
<h3>具名插巢</h3>
<card2>
<template>我喜歡這張卡片</template>
<!-- 預設請加入 default -->
<template>這是卡片 2</template>
<template>這是卡片腳</template>
</card2>
</div>
<script type="module">
const app = Vue.createApp({});
app.component('card2', {
template: `<div class="card" style="width: 18rem;">
<div class="card-header">
<slot>元件 Header</slot>
</div>
<div class="card-body">
<slot>這段是預設的文字</slot>
</div>
<div class="card-footer">
<slot>元件 Footer</slot>
</div>
</div>`
});

app.mount('#app');
</script>


這時我們可以發現HTML部分變成<template>標籤了,

而JS則有3塊<slot>,但是多開<slot>時沒給的名稱,

外層會不知道哪個要插哪的冏境,因此我們要給它個名稱name

app.component('card2', {
template: `<div class="card" style="width: 18rem;">
<div class="card-header">
<slot name="header">元件 Header</slot>
</div>
<div class="card-body">
<slot>這段是預設的文字</slot>
</div>
<div class="card-footer">
<slot name="footer">元件 Footer</slot>
</div>
</div>`
});


中間先刻意不加name展示,而內層已經有name了,

我們外層也給跟內層配合,所以要針對各<template>下達 v-slot:(內層名稱),

而中間剛剛刻意不加name這時如果有需要讓其也對應的話,

我們也可以幫它加個 v-slot:default 如下圖

<div id="app">
<h3>具名插巢</h3>
<card2>
<template v-slot:header>我喜歡這張卡片</template>
<!-- 預設請加入 default -->
<template v-slot:default>這是卡片 2</template>
<template v-slot:footer>這是卡片腳</template>
</card2>
</div>


此時結果就會變這樣
raw-image


可以隨個人需求調整的slot就完成了~


具名縮寫插槽

嫌v-slot太長嗎? 這邊也提供懶人寫法,

以剛剛的v-slot為例,只要將其改成如下就完成囉~

<div id="app">
<h3>具名插巢縮寫</h3>
<card2>
<template #header>我喜歡這張卡片</template>
<template #default>這是卡片 2</template>
<template #footer>這是卡片腳</template>
</card2>
</div>


  • joker
  • 2024/02/15
留言
avatar-img
留言分享你的想法!
avatar-img
Joker Cat
3會員
21內容數
是一隻喜愛前端勇往直前的霹靂酷樂貓
Joker Cat的其他內容
2024/06/04
平常我們在 html 上常看到的例如 v-for、v-model 等等... 也是VUE已經幫我們定義好的指令,而這次我們可以依這自己的需求來建立。 此功能屬於較進階的功能,因此實戰中會比較少見,市面上還是有不少完善的套件能達到同樣效果,建議可以先往這方面察找
Thumbnail
2024/06/04
平常我們在 html 上常看到的例如 v-for、v-model 等等... 也是VUE已經幫我們定義好的指令,而這次我們可以依這自己的需求來建立。 此功能屬於較進階的功能,因此實戰中會比較少見,市面上還是有不少完善的套件能達到同樣效果,建議可以先往這方面察找
Thumbnail
2024/06/03
我們在實作中,難免會遇到在不同組件中,卻有需求相同的資料格式,因此 mixins 可以達到我們的需求,除了 data 以外也包含了 methods 可以共用,舉例來說,學生資料可能會在,班級跟社團內被使用,當我們要撰寫元件時,就可以省略多餘的 data 定義。
Thumbnail
2024/06/03
我們在實作中,難免會遇到在不同組件中,卻有需求相同的資料格式,因此 mixins 可以達到我們的需求,除了 data 以外也包含了 methods 可以共用,舉例來說,學生資料可能會在,班級跟社團內被使用,當我們要撰寫元件時,就可以省略多餘的 data 定義。
Thumbnail
2024/05/30
VUE為單向資料流的框架,在鄰近層級之間我們可以依靠 props 由父層向子層來傳遞需要的資料,然而遇到跨層級的架構時,雖然也是可以一層層傳進去,只是這會造成多餘的處理及凌亂的程式碼,因此才有了 "provide" 來解決我們跨層級的需求。 層級展示圖
Thumbnail
2024/05/30
VUE為單向資料流的框架,在鄰近層級之間我們可以依靠 props 由父層向子層來傳遞需要的資料,然而遇到跨層級的架構時,雖然也是可以一層層傳進去,只是這會造成多餘的處理及凌亂的程式碼,因此才有了 "provide" 來解決我們跨層級的需求。 層級展示圖
Thumbnail
看更多
你可能也想看
Thumbnail
「欸!這是在哪裡買的?求連結 🥺」 誰叫你太有品味,一發就讓大家跟著剁手手? 讓你回購再回購的生活好物,是時候該介紹出場了吧! 「開箱你的美好生活」現正召喚各路好物的開箱使者 🤩
Thumbnail
「欸!這是在哪裡買的?求連結 🥺」 誰叫你太有品味,一發就讓大家跟著剁手手? 讓你回購再回購的生活好物,是時候該介紹出場了吧! 「開箱你的美好生活」現正召喚各路好物的開箱使者 🤩
Thumbnail
先前提到 Quasar 的 Dialog Plugin 很好用,再讓我補充一個用法。
Thumbnail
先前提到 Quasar 的 Dialog Plugin 很好用,再讓我補充一個用法。
Thumbnail
各位使用 Vue.js 開發的小夥伴們,你們都怎麼實作父子層組件資料的雙向綁定呢?如果你還在寫 prop + emit 的話,不妨進來看看吧。
Thumbnail
各位使用 Vue.js 開發的小夥伴們,你們都怎麼實作父子層組件資料的雙向綁定呢?如果你還在寫 prop + emit 的話,不妨進來看看吧。
Thumbnail
平常我們在 html 上常看到的例如 v-for、v-model 等等... 也是VUE已經幫我們定義好的指令,而這次我們可以依這自己的需求來建立。 此功能屬於較進階的功能,因此實戰中會比較少見,市面上還是有不少完善的套件能達到同樣效果,建議可以先往這方面察找
Thumbnail
平常我們在 html 上常看到的例如 v-for、v-model 等等... 也是VUE已經幫我們定義好的指令,而這次我們可以依這自己的需求來建立。 此功能屬於較進階的功能,因此實戰中會比較少見,市面上還是有不少完善的套件能達到同樣效果,建議可以先往這方面察找
Thumbnail
我們在實作中,難免會遇到在不同組件中,卻有需求相同的資料格式,因此 mixins 可以達到我們的需求,除了 data 以外也包含了 methods 可以共用,舉例來說,學生資料可能會在,班級跟社團內被使用,當我們要撰寫元件時,就可以省略多餘的 data 定義。
Thumbnail
我們在實作中,難免會遇到在不同組件中,卻有需求相同的資料格式,因此 mixins 可以達到我們的需求,除了 data 以外也包含了 methods 可以共用,舉例來說,學生資料可能會在,班級跟社團內被使用,當我們要撰寫元件時,就可以省略多餘的 data 定義。
Thumbnail
自訂元件生成位置顧名思義就是可以指定部分HTML區塊渲染在特定的畫面上,即使在不同組件也能把A組件內的部分畫面,展現在B組件上,以下方程式舉例。
Thumbnail
自訂元件生成位置顧名思義就是可以指定部分HTML區塊渲染在特定的畫面上,即使在不同組件也能把A組件內的部分畫面,展現在B組件上,以下方程式舉例。
Thumbnail
2023 Vue直播班筆記 - 動態路由Props,接續之前的一般動態路由。分為 "寫死" 及 "彈性" 兩種。
Thumbnail
2023 Vue直播班筆記 - 動態路由Props,接續之前的一般動態路由。分為 "寫死" 及 "彈性" 兩種。
Thumbnail
Vue Router 動態路由,假設有一個賣場,裡面有 100 個商品,我們不可能針對它們創 100 對應的路由,因此我們需要一個動態路由,利用"路徑帶參數"的方式來撈取商品的資訊。
Thumbnail
Vue Router 動態路由,假設有一個賣場,裡面有 100 個商品,我們不可能針對它們創 100 對應的路由,因此我們需要一個動態路由,利用"路徑帶參數"的方式來撈取商品的資訊。
追蹤感興趣的內容從 Google News 追蹤更多 vocus 的最新精選內容追蹤 Google News