vue如何使用slot

  • 1. vue2 如何使用slot
    • 1.1. 默认插槽(Default Slot)
    • 1.2. 具名插槽(Named Slot)
    • 1.3. 作用域插槽(Scoped Slot)
  • 2. vue3 如何使用slot
    • 2.1. 默认插槽(Default Slot)
    • 2.2. 具名插槽(Named Slot)
    • 2.3. 作用域插槽(Scoped Slot)
    • 2.4. 动态插槽名称

Vue 中使用 slot 的方式取决于你是使用 Vue 2 还是 Vue 3,因为这两个版本在插槽(Slot)的语法上有所不同。

下面是两个版本的基本使用方法:

1. vue2 如何使用slot

在 Vue 2 中,slot 是用来实现组件内容分发的一个关键特性,它允许你在父组件中定义一块内容,然后在子组件中决定如何展示这块内容。

Vue 2 提供了几种类型的 slots,包括默认插槽、具名插槽以及作用域插槽。以下是它们的基本使用方法:

1.1. 默认插槽(Default Slot)

默认插槽是最基本的用法,当你在一个组件中没有明确指定插槽名称时,内容将会被分配到默认插槽。

父组件使用:

<template>
  <child-component>
    <h1>我是父组件传递给子组件的内容</h1>
  </child-component>
</template>

子组件定义:

<template>
  <div class="child-component">
    <!-- 默认插槽内容将在这里被渲染 -->
    <slot></slot>
  </div>
</template>

1.2. 具名插槽(Named Slot)

具名插槽允许你有选择地插入内容到子组件的不同区域。

父组件使用:

<template>
  <child-component>
    <template v-slot:header>
      <h1>我是头部内容</h1>
    </template>
    <template v-slot:body>
      <p>我是主体内容</p>
    </template>
  </child-component>
</template>

子组件定义:

<template>
  <div class="child-component">
    <div class="header">
      <slot name="header"></slot>
    </div>
    <div class="body">
      <slot name="body"></slot>
    </div>
  </div>
</template>

1.3. 作用域插槽(Scoped Slot)

作用域插槽允许子组件向插槽传递数据。在 Vue 2 中,你可以使用 slot-scope 特性来接收这些数据。

父组件使用:

<template>
  <child-component>
    <template v-slot:default="{ item }">
      <span>{{ item.text }}</span>
    </template>
  </child-component>
</template>

子组件定义:

<template>
  <div class="child-component">
    <ul>
      <li v-for="item in items" :key="item.id">
        <slot :item="item"></slot>
      </li>
    </ul>
  </div>
</template>
<script>
export default {
  data() {
    return {
      items: [
        { id: 1, text: 'Item 1' },
        { id: 2, text: 'Item 2' }
      ]
    };
  }
};
</script>

请注意,从 Vue 2.6 开始,你可以使用简写的 v-slot 替换 slot-scope,使得代码更简洁:

使用 v-slot 的简化写法:

<!-- 父组件 -->
<template>
  <child-component>
    <template v-slot:default="slotProps">
      <span>{{ slotProps.item.text }}</span>
    </template>
  </child-component>
</template>

以上就是 Vue 2 中使用 slot 的基本方法。

更多详细内容,请微信搜索“前端爱好者戳我 查看

2. vue3 如何使用slot

Vue 3 对插槽的使用进行了简化,并推荐使用新的 v-slot 语法,即使对于默认插槽也是如此。

Vue 3 中对插槽(Slots)的使用进行了改进,使其更加灵活和直观。

以下是在 Vue 3 中使用插槽的基本方法:

2.1. 默认插槽(Default Slot)

默认插槽的使用方式与Vue 2相似,但语法稍有不同。Vue 3 中不再需要显式地使用 <slot> 标签,除非你需要配置特定的行为。

父组件使用:

<template>
  <ChildComponent>
    <h1>我是父组件传递给子组件的内容</h1>
  </ChildComponent>
</template>

子组件定义:

<template>
  <div class="child-component">
    <!-- 默认情况下,这里会自动渲染传递给组件的内容 -->
    <!-- 显式使用 <slot> 只是为了在需要时进行更复杂的设置 -->
  </div>
</template>

2.2. 具名插槽(Named Slot)

具名插槽的使用也保持了类似的逻辑,但现在使用 v-slot 指令更为简洁。

父组件使用:

<template>
  <ChildComponent>
    <template v-slot:header>
      <h1>我是头部内容</h1>
    </template>
    <template v-slot:body>
      <p>我是主体内容</p>
    </template>
  </ChildComponent>
</template>

子组件定义:

<template>
  <div class="child-component">
    <div class="header">
      <slot name="header"></slot>
    </div>
    <div class="body">
      <slot name="body"></slot>
    </div>
  </div>
</template>

2.3. 作用域插槽(Scoped Slot)

Vue 3 引入了新的 v-slot 语法,它不仅更简洁,还直接支持作用域插槽的传递。现在你可以直接在 v-slot 中解构来自子组件的数据。

父组件使用:

<template>
  <ChildComponent>
    <template v-slot:default="{ item }">
      <span>{{ item.text }}</span>
    </template>
  </ChildComponent>
</template>

子组件定义:

<template>
  <div class="child-component">
    <ul>
      <li v-for="item in items" :key="item.id">
        <slot :item="item"></slot>
      </li>
    </ul>
  </div>
</template>
<script setup>
import { ref } from 'vue';

const items = ref([
  { id: 1, text: 'Item 1' },
  { id: 2, text: 'Item 2' }
]);
</script>

2.4. 动态插槽名称

Vue 3 还支持动态插槽名称,通过将 v-slot 绑定到一个变量即可实现。

<template>
  <ChildComponent>
    <template v-for="(content, name) in slotsContent" :v-slot:[name]>
      {{ content }}
    </template>
  </ChildComponent>
</template>

Vue 3 中插槽的改进旨在简化API并提高可读性,同时保持了Vue组件间内容复用的强大能力。

Vue 3 中 v-slot 语法是标准用法,即使对于默认插槽也是如此,尽管默认插槽在子组件中可能不需要显式的 <slot> 标签。

此外,Vue 3 引入了Composition API,这会影响子组件内部状态管理的方式,但对插槽的使用影响不大。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/695216.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Nginx高级配置及重写功能

文章目录 一、高级配置网页的状态页Nginx第三方模块变量访问日志Nginx压缩功能https功能自定义小图标 二、重写功能&#xff08;rewrite&#xff09;if指令return指令set指令break指令rewrite指令防盗链 一、高级配置 网页的状态页 状态页显示的是整个服务器的状态而非虚拟主…

【Node.js快速部署opencv项目】图像分类与目标检测

⭐️我叫忆_恒心&#xff0c;一名喜欢书写博客的研究生&#x1f468;‍&#x1f393;。 如果觉得本文能帮到您&#xff0c;麻烦点个赞&#x1f44d;呗&#xff01; 近期会不断在专栏里进行更新讲解博客~~~ 有什么问题的小伙伴 欢迎留言提问欧&#xff0c;喜欢的小伙伴给个三连支…

Linux系统管理:虚拟机Almalinux 9.4 安装

目录 一、理论 1.Almalinux 二、实验 1.虚拟机Almalinux 9.4 安装准备阶段 2.安装Almalinux 9.4 3.Termius远程连接 一、理论 1.Almalinux (1) 简介 Almalinux是一个开源、社区拥有和管理、免费的企业Linux发行版。专注于长期稳定性&#xff0c;并提供强大的生产级…

按键精灵安装有乱码并且不能启动的解决办法

在国外购了电脑&#xff0c;系统是英文版 Windows 11&#xff0c;按键精灵死活都装不上去&#xff0c;打开exe的安装文件后出现乱码&#xff0c;安装完了后还是乱码&#xff0c;并且启动不了&#xff0c;以下是解决办法&#xff1a; 进入控制面板&#xff0c;并且点 Region&am…

TIM—通用定时器

通用定时器的功能 在基本定时器功能的基础上新增功能&#xff1a; 通用定时器有4个独立通道&#xff0c;且每个通道都可以用于下面功能。 &#xff08;1&#xff09;输入捕获&#xff1a;测量输入信号的周期和占空比等。 &#xff08;2&#xff09;输出比较&#xff1a;产生输…

vs2019 c++20规范 全局函数 ref 及模板类 reference_wrapper<_Ty> 的源码分析

这是个引用&#xff0c;可以包裹一个对象&#xff0c;相当于引用该对象&#xff0c;而不是在作为函数形参时产生值传递。因为模板 reference_wrapper<_Ty> 其实是封装了该对象的地址。下面以图示形式给出其重要的成员函数。模板其实都差不多&#xff0c;跟人也一样&#…

6月7号作业

1&#xff0c; 搭建一个货币的场景&#xff0c;创建一个名为 RMB 的类&#xff0c;该类具有整型私有成员变量 yuan&#xff08;元&#xff09;、jiao&#xff08;角&#xff09;和 fen&#xff08;分&#xff09;&#xff0c;并且具有以下功能&#xff1a; (1)重载算术运算符…

浅谈提示词发展现状,Prompt 自动优化是未来。

#封面手绘于本科期间&#xff0c;当年在知乎上写的第一篇关于 AI 的文章就用的这个封面&#xff0c;聊表纪念。 这次我们来聊聊 Prompt. 本来想取一个类似“提示词不存在了…”&#xff0c;或是“再见&#xff0c;Prompt 课程…”的标题&#xff0c;但最近很多大佬的谬赞让我感…

2024世界技能大赛某省选拔赛“网络安全项目”B模块--数据包分析(jsp流量解密)

2024世界技能大赛某省选拔赛“网络安全项目”B模块--数据包分析② 任务一、网络数据包分析取证解析:任务一、网络数据包分析取证解析: A 集团的网络安全监控系统发现有恶意攻击者对集团官方网站进行攻击,并抓取了部分可疑流量包。请您根据捕捉到的流量包,搜寻出网络攻击线…

SpringBoot引入WebSocket依赖报ServerContainer no avaliable

1、WebSocketConfig 文件报错 Configuration EnableWebSocket public class WebSocketConfig {Beanpublic ServerEndpointExporter serverEndpointExporter() {return new ServerEndpointExporter();}2、报错内容 Exception encountered during context initialization - canc…

golang协程工作池处理多任务示例

1. 工作方法实现 // 工作线程 // id : 线程号 // jobs : 任务通道 (chan) // results: 完成结果通道 (chan) func worker(id int, jobs <-chan int, results chan<- int) {//遍历任务for j : range jobs {fmt.Println("工作协程: ", id, "启动任务: &quo…

linux-ubuntu20网卡驱动安装AX201

https://blog.csdn.net/vor234/article/details/131682778 联想拯救者Y7000P2023 Ubuntu20.04网卡驱动AX211安装 幻14 ubuntu20.04 AX210驱动安装 官网下载相应的驱动&#xff1a;https://www.intel.com/content/www/us/en/support/articles/000005511/wireless.html sudo a…

图像处理ASIC设计方法 笔记29 场景自适应校正算法

P152 7.2.3 场景自适应校正算法 (一)Scribner提出的神经网络非均匀性校正算法 非均匀性校正(Non-Uniformity Correction,简称NUC)算法是红外成像技术中非常重要的一个环节。它主要用于校正红外焦平面阵列(Infrared Focal Plane Arrays,简称IRFPA)中的固定模式噪声,以提…

Objective-C 学习笔记 | 回调

Objective-C 学习笔记 | 回调 Objective-C 学习笔记 | 回调运行循环目标-动作对&#xff08;target-action&#xff09;辅助对象通知回调与对象所有权深入学习&#xff1a;选择器的工作机制 参考书&#xff1a;《Objective-C 编程&#xff08;第2版&#xff09;》 Objective-C…

Docker 基础使用 (4) 网络管理

文章目录 Docker 网络管理需求Docker 网络架构认识Docker 常见网络类型1. bridge 网络2. host 网络3. container 网络4. none 网络5. overlay 网络 Docker 网路基础指令Docker 网络管理实操 其他相关链接 Docker 基础使用(0&#xff09;基础认识 Docker 基础使用(1&#xff09;…

数据结构---树与二叉树

个人介绍 hello hello~ &#xff0c;这里是 code袁~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f981;作者简介&#xff1a;一名喜欢分享和记录学习的…

TalkingData 是一家专注于提供数据统计和分析解决方案的独立第三方数据智能服务平台

TalkingData 是一家专注于提供数据统计和分析解决方案的独立第三方数据智能服务平台。通过搜索结果&#xff0c;我们可以了解到 TalkingData 的一些关键特性和市场情况&#xff0c;并将其与同类型产品进行比较。 TalkingData 产品特性 数据统计与分析&#xff1a;提供专业的数…

复数乘法IP核的使用

一、IP核解析 在这张图片中&#xff0c;我们看到的是一个“Complex Multiplier (6.0)” IP 核的配置界面。以下是各个配置参数的详细说明&#xff1a; 1.1 Multiplier Construction Use LUTs: 选择这个选项时&#xff0c;乘法器将使用查找表&#xff08;LUTs&#xff09;来实现…

TiDB-从0到1-配置篇

TiDB从0到1系列 TiDB-从0到1-体系结构TiDB-从0到1-分布式存储TiDB-从0到1-分布式事务TiDB-从0到1-MVCCTiDB-从0到1-部署篇TiDB-从0到1-配置篇 一、系统配置 TiDB的配置分为系统配置和集群配置两种。 其中系统配置对应TiDB Server&#xff08;不包含TiKV和PD的参数&#xff0…

显示子系统,显示子前后端,linuxfb,wayland

显示前端 显示前端通常指的是在图形系统中负责生成图形数据的部分或组件。它负责接收来自应用程序或图形引擎的图形数据&#xff0c;并将其转换成适合显示的格式&#xff0c;以便发送到显示后端进行处理和输出。 显示前端的功能通常包括以下几个方面&#xff1a; 图形数据生…