news 2026/4/23 12:03:04

Vue-插槽 (Slot) 的多种高级玩法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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)需要自定义时使用。
作用域插槽需要根据子组件的内部数据来决定父组件渲染样式的场景(如列表展示)。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 19:47:09

网络安全从入门到入狱,2026黑客技术路线图

网络安全从入门到入狱&#xff0c;2026黑客技术路线图 网络安全世界瞬息万变&#xff0c;攻防技术日新月异。2026年&#xff0c;随着AI深度融入、量子计算威胁初显、物联网设备爆炸式增长&#xff0c;以及法规合规要求日益严格&#xff08;如中国的《数据安全法》、《个人信息保…

作者头像 李华
网站建设 2026/4/19 18:43:05

5款AI写论文哪个好?实测避坑!宏智树AI凭真实硬实力封神

作为深耕论文写作科普的教育测评博主&#xff0c;毕业季后台被问爆的问题只有一个&#xff1a;“5款热门AI写论文工具实测&#xff0c;哪款能真正搞定毕业论文&#xff1f;不踩坑、不造假、高效率&#xff1f;”不同于市面上“泛泛而谈”的测评&#xff0c;我花了10天时间&…

作者头像 李华
网站建设 2026/4/3 4:45:54

矢量网络分析仪(VNA)毫米波光

一、内容简介 在光通信链路中增加聚合带宽的愿望并没有减少。多年来&#xff0c;这一增长主要是通过复用额外的光波长&#xff08;或其他光学参数&#xff09;或改变调制技术来实现的&#xff0c;但可能不会增加单载波调制带宽。最近&#xff0c;人们还希望增加这些调制带宽&am…

作者头像 李华
网站建设 2026/4/18 8:02:11

SQL生成报错大模型回答结果不固定(dify)

我个人在dify制作查询数据库得出的心得。废话不多说。SQL生成报错问题&#xff1a;SQL生成会存在一定的报错概率&#xff0c;需要大量的提示词限制才能减少报错的几率&#xff0c;最高可以控制在90%-95%左右&#xff0c;不可能100%的&#xff0c;根本原因就在于“大模型”&…

作者头像 李华
网站建设 2026/4/18 6:39:35

演讲回顾|Apache Pulsar 延迟消息深度剖析与混合架构演进

本文整理自 刘思楠&#xff08;Denovo1998&#xff09; 在 Pulsar Developer Day 2025 上的主题演讲&#xff0c;一起来看 Apache Pulsar 如何通过混合架构突破延迟消息的性能与功能瓶颈&#xff01; 01 延迟消息的应用场景与定义 在现代分布式系统中&#xff0c;延迟消息是一个…

作者头像 李华