Vue-插槽(Slots)

1. 介绍

在Vue.js中,插槽是一种强大的功能,它允许你创建可重用的模板,并在使用该模板的多个地方插入自定义内容。

插槽为你提供了一种方式,可以在父组件中定义一些“插槽”,然后在子组件中使用这些插槽,插入自己的内容。

2. 插槽的分类

2.1 默认插槽(Default Slots)

这是最常见的插槽类型。如果你在一个组件模板中定义一个slot素,那么这个元素将被视为默认插槽的内容。

使用场景:只需要传入一个结构

案例:

  • 子组件(ChildComponent.vue):
<template>  <div>  <slot>默认内容</slot> <!-- 默认插槽 --> <!-- 里面可以包含默认内容,父组价没有传递,就展示默认内容 --> </div>  
</template>
  • 父组件(ParentComponent.vue)
<template>  <ChildComponent>  <p>这是插入到默认插槽的内容</p>  <!-- 没有就展示子组件的默认内容,这里:可以为任意的html内容 --> </ChildComponent>  
</template>

2.2 具名插槽(Named Slots)

具名插槽允许你在父组件中为子组件的特定部分提供内容。你可以通过在子组件的模板中添加slot标签,并为其指定一个名字,来定义具名插槽。

使用场景:一个组件内有多处结构,需要外部传入标签,进行定制 。

案例:

  • 子组件(ChildComponent.vue)
<template>  <div>  <slot name="header"></slot> <!-- 具名插槽 name="header"-->  <slot name="footer"></slot> <!-- 具名插槽 name="footer" -->  </div>  
</template>
  • 父组件(ParentComponent.vue)
<template>  <ChildComponent>  <template v-slot:header> <!-- 指定要插入到具名插槽的内容 -->  <!-- 这里的v-slot:可以替换为 # -->  <h1>这是头部内容</h1>  </template>  <template #footer> <!-- 指定要插入到具名插槽的内容 -->  <p>这是底部内容</p>  </template>  </ChildComponent>  
</template>

注:v-slot:可以替换为 #,方便进行简写

2.3 作用域插槽(Scoped Slots)

作用域插槽是一种特殊的具名插槽,它允许你访问子组件的数据和方法。通过作用域插槽,你可以在父组件中操作子组件的数据。

使用场景:封装表格组件

基本使用步骤:

  1. 给 slot 标签, 以 添加属性的方式传值
<slot :id="item.id" msg="测试文本"></slot>
  1. 所有添加的属性, 都会被收集到一个对象中
{ id: 3, msg: '测试文本' }
  1. 在template中, 通过 #插槽名= "obj" 接收,并使用,默认插槽名为 default
<MyTable :list="list"><template #default="obj"><button @click="del(obj.id)">删除</button></template>
</MyTable>

案例:

需求:假设我们有一个子组件ListComponent,它包含一个列表,并且我们希望在父组件中自定义每个列表项的内容。我们可以使用作用域插槽来实现这个需求。

  • 子组件(ListComponent.vue)
<template>  <ul>  <li v-for="item in items" :key="item.id">  <slot name="item" :item="item"></slot> <!-- 作用域插槽 -->  </li>  </ul>  
</template>
  • 父组件(ParentComponent.vue)
<template>  <ListComponent :items="items"> <!-- 将数据传递给子组件 -->  <template #item="{ item }"> <!-- 访问子组件的数据  这里使用了 js的对象解析-->  <p>{{ item.name }}</p> <!-- 使用子组件的数据 -->  <p>{{ item.description }}</p> <!-- 使用子组件的数据 -->  </template>  </ListComponent>  
</template>

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQL-分组查询

&#x1f389;欢迎您来到我的MySQL基础复习专栏 ☆* o(≧▽≦)o *☆哈喽~我是小小恶斯法克&#x1f379; ✨博客主页&#xff1a;小小恶斯法克的博客 &#x1f388;该系列文章专栏&#xff1a;重拾MySQL &#x1f379;文章作者技术和水平很有限&#xff0c;如果文中出现错误&am…

turnjs实现翻书效果

需求&#xff1a;要做一个效果&#xff0c;类似于阅读器上的翻书效果。 咱们要实现这个需求就需要使用turnjs这个插件&#xff0c;他的官网是turnjs官网。 进入官网后可以点击 这个按钮去下载官网的demo。 这个插件依赖于jQuery&#xff0c;所以你的先安装jQuery. npm insta…

面试官:实际工作中哪里用到了自定义注解?

自定义注解可以标记在方法上或类上&#xff0c;用于在编译期或运行期进行特定的业务功能处理。在 Java 中&#xff0c;自定义注解使用 interface 关键字来定义&#xff0c;它可以实现如&#xff1a;日志记录、性能监控、权限校验等功能。 在 Spring Boot 中实现一个自定义注解&…

Unity URP下阴影锯齿

1.概述 在Unity开发的URP项目中出现阴影有明显锯齿。如下图所示&#xff1a; 并且在主光源的Shadow Type已经是Soft Shadows模式了。 2.URP Asset 阴影出现锯齿说明阴影质量不高&#xff0c;所以要先找到URP Asset文件进行阴影质量参数的设置。 1.打开PlayerSetting找到Graph…

代码签名证书怎么选择?软件开发者必看

随着互联网的高速发展&#xff0c;各种购物、资讯、社交类软件高速增长。而对于软件开发者来说&#xff0c;选择合适的代码签名证书来为软件进行数字签名、确保软件程序代码的完整性和软件的可信任性是很有必要的。但市场上有多种品牌、多种类型的代码签名证书可以选择&#xf…

03.阿里Java开发手册——OOP规约

【强制】避免通过一个类的对象引用访问此类的静态变量或静态方法&#xff0c;无谓增加编译器解析成本&#xff0c;直接用类名来访问即可。 【强制】所有的覆写方法&#xff0c;必须加Override 注解。 说明&#xff1a;getObject()与 get0bject()的问题。一个是字母的 O&#x…

git pull 时 配置适合自己的合并策略 git config pull.rebase

当 git pull 时有可能遇到以下的提示 hint: git config pull.rebase false # merge (the default strategy) hint: git config pull.rebase true # rebase hint: git config pull.ff only # fast-forward only这三个配置项影响git pull的默认行为。以下是对它们…

tab分页高亮切换及tab交互

当用户点击页面中的 Tab 后&#xff0c;切换展示相应的商品列表&#xff0c;功能相对简单&#xff0c;快速实现即可。 // 存储高亮的下标 <script setup lang"ts"> // 高亮的下标 const activeIndex ref(0) </script><template><!-- 推荐选项…

vue前端开发自学,插槽练习,同时渲染父子组件的数据信息

vue前端开发自学,插槽练习,同时渲染父子组件的数据信息&#xff01; 如果想在slot插槽出口里面&#xff0c;同时渲染出来&#xff0c;来自父组件的数据&#xff0c;和子组件自身的数据呢。又有点绕口了。vue官方给的解决办法是。需要借助于&#xff0c;父组件的自定义属性。 …

第二百五十九回

文章目录 知识回顾示例代码经验总结 我们在上一章回中介绍了MethodChannel的使用方法&#xff0c;本章回中将介绍EventChannel的使用方法.闲话休提&#xff0c;让我们一起Talk Flutter吧。 知识回顾 我们在前面章回中介绍了通道的概念和作用&#xff0c;并且提到了通道有不同的…

Unity 面试篇|(一)C#基础篇 【全面总结 | 持续更新】

目录 1. 面向对象的三大特点2. 简述值类型和引用类型3.重载和重写的区别4.C#中所有引用类型的基类是什么5.请简述ArrayList和 List的主要区别6.GC 相关知识点7.结构体和类8.C#中四种访问修饰符是哪些&#xff1f;各有什么区别&#xff1f;9.修饰符 简述private&#xff0c;publ…

本地部署Canal笔记-实现MySQL与ElasticSearch7数据同步

背景 本地搭建canal实现mysql数据到es的简单的数据同步&#xff0c;仅供学习参考 建议首先熟悉一下canal同步方式&#xff1a;https://github.com/alibaba/canal/wiki 前提条件 本地搭建MySQL数据库本地搭建ElasticSearch本地搭建canal-server本地搭建canal-adapter 操作步骤…

24-1-9 bilibilic++音视频

下午两点面试&#xff0c;面试官迟到了一会&#xff0c;面试官人很好&#xff0c;整体面试经历很不错&#xff0c;但是我人太紧张了&#xff0c;基础知识掌握的深度不够&#xff0c;没有深挖&#xff0c; 是做音视频的底层相关的&#xff0c; 实习要求只要每天打卡够九个小时就…

【高可用】SQL Server 2019 无域+WSFC搭建Always On环境图文步骤

SQL Server 2019 无域搭建Always On环境 简介环境介绍服务器配置安装故障转移修改主机名并加入域修改hosts文件关闭防火墙修改DNS新建故障转移集群(任一台服务器)验证故障转移是否成功(任意一台电脑关机)设置共享文件数据库安装数据库配置数据库开启Always On在数据库里面安…

禁用code server docker容器中的工作区信任提示

VSCode 添加受限模式&#xff0c;主要是防止自动运行代码的&#xff0c;比如在vscode配置的task和launch参数是可以运行自定义代码的。如果用VScode打开未知的工程文件就有可能直接运行恶意代码。 但是当我们的实验基础模板文件可控的情况下&#xff0c;要想禁用code server do…

vue前端开发自学,组件的嵌套关系demo

vue前端开发自学,组件的嵌套关系demo!今天开始分享的&#xff0c;前端开发经常用到的&#xff0c;组件的嵌套关系案例代码。下面先给大家看看&#xff0c;代码执行效果。 如图&#xff0c;这个是代码执行后&#xff0c;的效果布局&#xff01; 下面给大家贴出来源码。方便大家…

认识字面量

字面量&#xff1a;数据在程序中的书写格式 整数小数写法无变化 字符&#xff1a;在程序中必须使用单引号&#xff0c;有且只能有一个字符 字符串&#xff1a;程序中必须使用双引号&#xff0c;内容可有可无 布尔值&#xff1a;true、false 空值&#xff1a;null 示例和结…

使用spark将MongoDB数据导入hive

使用spark将MongoDB数据导入hive 一、pyspark 1.1 pymongospark 代码 import json,sys import datetime, time import pymongo import urllib.parse from pyspark.sql import SparkSession from pyspark.sql.types import StructType, StructField, StringType127.0.0.1 27…

功效产品如何做好营销?媒介盒子解答

功能性产品目前的营销痛点就在于宣传夸张导致用户信任度降低&#xff0c;尤其是健康类产品&#xff0c;作为消费者&#xff0c;对此类产品大多持观望态度&#xff0c;但媒介盒子作为提供品牌宣传服务的团队&#xff0c;想和大家聊聊&#xff1a;功能性产品除了在功能上进行宣传…

【Java】解决Servlet编程中出现的中文乱码问题

1、引言 前面两篇文章我们讲述了编写Servlet程序的基本步骤和修改一个Servlet程序 【Java】编写一个简单的Servlet程序​​​​​​ 【Java】SmartTomcat的配置及使用 上面两篇文章的示例代码都是使用的全英文&#xff0c;当我们编写中文&#xff0c;发现似乎出了一点点问题…