Vue中插槽Slot的多种高级玩法详解

 更新时间:2026年02月02日 09:18:03   作者:发现一只大呆瓜  
在组件化开发中,插槽 (Slot) 是实现内容分发的核心机制,这篇文章小编为大家整理了一些Vue插槽Slot的高级玩法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下

前言

在组件化开发中,插槽 (Slot) 是实现内容分发(Content Distribution)的核心机制。它允许我们将组件的“外壳”与“内容”解耦,让组件具备极高的扩展性。

一、 什么是插槽

插槽是子组件提供给父组件的 “占位符” ,用 <slot></slot> 标签表示。父组件传递的任何模板代码(HTML、组件等)都会替换子组件中的 <slot> 标签。

二、 插槽的三大类型

1. 默认插槽 (Default Slot)

最基础的插槽,不需要定义 name 属性。

特点:一个子组件通常只建议使用一个默认插槽。

示例:

 <!-- 子组件 -->
  <template>
    <div class="card">
      <div class="card-title">通用卡片标题</div>
      <div class="card-content">
        <slot> 这里是默认的填充文本 </slot>
      </div>
    </div>
  </template>
 <!-- 父组件 -->
  <template>
    <div class="app">
      <MyCard> 这是我传递给卡片的具体内容。 </MyCard>
    </div>
  </template>

2. 具名插槽 (Named Slots)

当子组件需要多个占位符时,通过 name 属性来区分。

语法糖v-slot:header 可以简写为 #header

示例:

 <!-- 子组件:LayoutComponent.vue -->
<template>
  <div class="layout">
    <header class="header">
      <slot name="header"></slot>
    </header>
    
    <main class="content">
      <slot></slot> 
    </main>
    
    <footer class="footer">
      <slot name="footer"></slot>
    </footer>
  </div>
</template>

<script setup lang="ts">
 <!-- Vue 3 Composition API 模式下,逻辑部分可以保持简洁 -->
</script>
 <!-- 父组件使用示例 -->
<template>
  <LayoutComponent>
    <template #header>
      <h1>页面标题</h1>
      <nav>导航菜单</nav>
    </template>
    
    <p>这是主体内容,将填充到默认插槽中...</p>
    
    <template #footer>
      <p>版权信息 &copy; 2026</p>
    </template>
  </LayoutComponent>
</template>

<script setup lang="ts">
import LayoutComponent from './LayoutComponent.vue';
</script>

3. 作用域插槽 (Scoped Slots)

核心价值“子传父” 的特殊形式。子组件将内部数据绑定在 <slot> 上,父组件在填充内容时可以接收并使用这些数据。

示例:

 <!-- 子组件:`UserList.vue` -->
<template>
  <ul>
    <li v-for="user in users" :key="user.id">
      <slot :user="user" :index="user.id">
        {{ user.name }}
      </slot>
    </li>
  </ul>
</template>

<script setup lang="ts">
interface User {
  id: number;
  name: string;
  role: string;
}

const users: User[] = [
  { id: 1, name: '张三', role: '管理员' },
  { id: 2, name: '李四', role: '开发者' }
];
</script>
 <!-- 父组件使用示例 -->
<template>
  <UserList>
    <template #default="{ user }">
      <span :style="{ color: user.role === '管理员' ? 'red' : 'blue' }">
        {{ user.name }} - 【{{ user.role }}】
      </span>
    </template>
  </UserList>
</template>

三、 补充:插槽的默认内容

在子组件中,你可以在 <slot> 标签内部放置内容。如果父组件没有提供任何插槽内容,则会渲染这些“后备内容”;如果提供了,则会被覆盖。

<slot>这是如果没有内容时显示的默认文本</slot>

四、 总结:如何选择插槽?

插槽类型使用场景
默认插槽组件只有一个扩展点时使用。
具名插槽组件有多个固定区域(如 Header/Main/Footer)需要自定义时使用。
作用域插槽需要根据子组件的内部数据来决定父组件渲染样式的场景(如列表展示)。

到此这篇关于Vue中插槽Slot的多种高级玩法详解的文章就介绍到这了,更多相关Vue插槽Slot内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue $mount 和 el的区别说明

    vue $mount 和 el的区别说明

    这篇文章主要介绍了vue $mount 和 el的区别说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • Elementui如何限制el-input框输入小数点

    Elementui如何限制el-input框输入小数点

    这篇文章主要介绍了Elementui如何限制el-input框输入小数点,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • Vue微信项目按需授权登录策略实践思路详解

    Vue微信项目按需授权登录策略实践思路详解

    这篇文章主要介绍了Vue微信项目按需授权登录策略实践思路详解,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-05-05
  • Vue3中的script setup语法糖的使用及说明

    Vue3中的script setup语法糖的使用及说明

    在这篇博客中,我们将探讨 script setup 的含义、好处以及示例代码,帮助你更好地理解并在项目中合理运用这一特性,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-03-03
  • vue键盘事件keyup、keydown的作用

    vue键盘事件keyup、keydown的作用

    这篇文章主要介绍了vue键盘事件keyup、keydown的作用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • vue3.0中的keep-alive使用及说明

    vue3.0中的keep-alive使用及说明

    这篇文章主要介绍了vue3.0中的keep-alive使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • vue2.0项目实现路由跳转的方法详解

    vue2.0项目实现路由跳转的方法详解

    这篇文章主要介绍了vue2.0项目实现路由跳转的详细方法,非常不错,具有一定的参考借鉴借鉴价值,需要的朋友可以参考下
    2018-06-06
  • Element-UI实现复杂table表格结构的操作代码

    Element-UI实现复杂table表格结构的操作代码

    Element-UI组件el-table用于展示多条结构类似的数据,可对数据进行排序、筛选、对比或其他自定义操作,本文给大家介绍Element-UI实现复杂table表格结构的操作代码,感兴趣的朋友一起看看吧
    2023-12-12
  • Vue引入路径正确但一直报错问题:Already included file name ‘××ב differs from file name ‘××ב only in casing.

    Vue引入路径正确但一直报错问题:Already included file name&n

    这篇文章主要介绍了Vue引入路径正确但一直报错:Already included file name ‘××ב differs from file name ‘××ב only in casing.具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • 详解关于element级联选择器数据回显问题

    详解关于element级联选择器数据回显问题

    这篇文章主要介绍了详解关于element级联选择器数据回显问题,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-02-02

最新评论