Vue前端开发-slot传参

news/2024/11/28 4:56:15/

slot 又称插槽,它是在子组件中为父组件提供的一个占位符,使用来表示,通过这个占位符,父组件可以向中填充任意的内容代码,这些代码将自动替换占位符的位置,从而轻松实现在父组件中控制子组件内容的需求。

作用域插槽

插槽分为三种,分别为匿名插槽、具名插槽和作用域插槽,与前两种只能各自访问自己组件的内容不同,作用域插槽可以在父组件中访问到子组件的内容,使用非常灵活。

接下来,结合一个完整的实例需求,来演示在作用域插槽中,父组件如何访问和过滤子组件传入的参数。

实例7-5 作用域插槽传参

1. 功能描述

在一个父组件中,添加一个子组件,子组件中以作用域插槽的方式为父组件提供数据源,父组件显示子组件数据时,隐藏索引号等于0的内容。

2. 实现代码

在项目的components 文件夹中,添加一个名为“Parent”的.vue文件,该文件的保存路径是“components/ch7/part5/”,在文件中加入如清单7-11所示代码。

代码清单7-11 Parent.vue代码

<template><child><template v-slot:header="slotProps"><div class="info" v-show="slotProps.index != 0">{{ slotProps }},姓名--{{ slotProps.item }}, 
序号--{{ slotProps.index }}</div></template></child>
</template>
<script>
import Child from "./Child.vue"
export default {components: {Child}
}
</script>
<style scoped>
.info{margin: 10px 0;padding: 5px 0;width: 400px;border-bottom: solid 1px #ccc;
}
</style>

在父组件中,导入子组件 Child.vue文件,它的功能是将遍历后的数组项,以插槽的方式作为父组件显示的数据源,它的代码如清单7-12所示。

代码清单7-12 Child.vue代码

<template><div v-for="(item, index) in arr" :key="index"><slot :item="item" name="header" :index="index">
</slot></div><button @click="add">增加</button>
</template>
<script>
export default {data(){return{arr:["张明明","李小华","王忠远"]}},methods:{add(){this.arr.push("陶国荣")}}
}
</script>

3. 页面效果

保存代码后,页面在Chrome浏览器下执行的页面效果如图7-6所示。
在这里插入图片描述

4. 源码分析

在本实例的子组件Child源码中,为了使父组件Parent能直接访问到传入的数据源,首先,借助插槽slot标签向父组件传入数据,并以标签属性prop的形式,向父组件暴露可以访问的属性名,当父组件使用template标签替换slot标签时,就可以调用template中v-slot 属性直接获取子组件传入的数据,并对数据执行过滤操作。

需要说明的是:通过template标签中v-slot属性获取的是一个对象,它包含slot标签中全部暴露传入的属性内容,因此,如果想获取某个内容属性值时,需要采用对象名.属性名的形式就可以直接获取到单个传入的属性值。
在这里插入图片描述


http://www.ppmy.cn/news/1550535.html

相关文章

R中单细胞RNA-seq数据分析教程 (2)

引言 本系列开启R中单细胞RNA-seq数据分析教程[1]&#xff0c;持续更新&#xff0c;欢迎关注&#xff0c;转发&#xff01; 导入Seurat包 首先&#xff0c;请确认你的R软件已经安装了Seurat这个包。 library(Seurat) 这会将您已安装的Seurat包载入您当前的R环境中。通常不会出现…

Android 项目引入gradle Connect timed out

Could not install Gradle distribution from https://services.gradle.org/distributions/gradle-6.7.1-all.zip. Reason: java.net.SocketTimeoutException: Connect timed out 通过离线下载对应版本的gradle Index of /gradle/ 打开配置文件&#xff1a;gradle/wrapper…

自主研发,基于PHP+ vue2+element+ laravel8+ mysql5.7+ vscode开发的不良事件管理系统源码,不良事件管理系统源码

不良事件上报系统源码&#xff0c;不良事件管理系统源码&#xff0c;PHP源码 不良事件上报系统通过 “事前的人员知识培训管理和制度落地促进”、“事中的事件上报和跟进处理”、 以及 “事后的原因分析和工作持续优化”&#xff0c;结合预存上百套已正在使用的模板&#xff0…

HTML常用表格与标签

一、table表格标签&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title> </head> <body> <!--有大小为1的边框--> <table border"1">…

2686694 - 操作方法:MSEG - DBSQL_REDIRECT_INCONSISTENCY

2686694 - 操作方法&#xff1a;MSEG - DBSQL_REDIRECT_INCONSISTENCY SAP Note, Version: 4, 审批日期: 24.04.2023 显示更改 组件MM-IM-GF对象状态 优先级建议/附加信息对象状态 类别咨询对象状态 审批状态已发布至客户对象状态 更正0对象状态 手动活动0对象状态已成…

深度学习之U-Net

卷积网络被大规模应用在分类任务中&#xff0c;输出的结果是整个图像的类标签。然而&#xff0c;在许多视觉任务&#xff0c;尤其是生物医学图像处理领域&#xff0c;目标输出应该包括目标类别的位置&#xff0c;并且每个像素都应该有类标签。另外&#xff0c;在生物医学图像往…

Hive的基础函数

字符串函数 -- lower&#xff08;转小写&#xff09; select lower(ABC); --upper&#xff08;转大写&#xff09; select upper(abc); --length&#xff08;字符串长度&#xff0c;字符数&#xff09; select length(abc); -- concat&#xff08;字符串拼接&#xff09; sele…

Python数据分析实例五、US 大选捐款数据分析

美国联邦选举委员会 (FEC) 公布了对政治竞选活动的贡献数据。这包括投稿人姓名、职业和雇主、地址和投款金额。2012 年美国总统大选的贡献数据以单个 150 MB 的 CSV 文件P00000001-ALL.csv形式提供,该文件可以通过以下pandas.read_csv加载: import pandas as pdfec = pd.r…