当前位置: 首页 > news >正文

vue3插槽solt 使用

 背景增加组件的复用性,个人体验组件化还是react 方便。

Vue插槽solt如何传递具名插槽的数据给子组件?

一、solt 原理

知其然知其所以然

Vue的插槽(slots)是一种分发内容的机制,允许你在组件模板中定义可插入的内容,然后在使用组件的地方提供这些内容。

插槽的工作原理是这样的:

  1. 当Vue编译一个组件模板时,它会查找所有的<slot>元素。每个<slot>元素都代表一个插槽。

  2. 对于每个插槽,Vue会查看它是否有名字(通过name属性指定)。如果有,那么它就是一个具名插槽;如果没有,那么它就是一个默认插槽。

  3. 当Vue渲染一个组件时,它会查看组件的父上下文中是否提供了插槽内容。如果提供了,那么Vue会用这些内容替换掉插槽;如果没有提供,那么Vue会使用插槽的默认内容(如果有的话)。

  4. 插槽内容是在父上下文中编译的,但是它们可以访问子上下文中的数据。这是通过作用域插槽实现的,你可以在插槽内容中使用特殊的<template>元素,并通过v-slot指令提供一个可以访问子上下文中数据的模板。

这就是Vue插槽的基本工作原理。插槽是Vue组件系统的一个重要部分,它们提供了一种灵活的方式来组合和重用组件。

二、单个插入结构

子组件

上文略....<el-table :data="tableData" style="width: 100%"><slot></slot>
</el-table>下文略....

父组件中,你可以这样使用ExportRecordsModal组件,并填充插槽:

<ExportRecordsModalv-model:diaShow="diaShow":onDialogClose="onDialogClose":onDownLoad="downLoad":tableData="tableDataList":diaPagination="diaPagination":sizeChangeDia="sizeChangeDia":currentChangeDia="currentChangeDia"
>// 插槽DOM<el-table-column label="导出时间"><template #default="scope"><span>{{ scope.row.createTime }}</span></template></el-table-column>
</ExportRecordsModal>

三、多个插槽

子组件

上文略....<el-table :data="props.tableData" style="width: 100%"><slot name="column1"></slot><slot name="column2"></slot>
</el-table>下文略....

父组件

<ExportRecordsModalv-model:diaShow="diaShow":onDialogClose="onDialogClose":onDownLoad="downLoad":tableData="tableDataList":diaPagination="diaPagination":sizeChangeDia="sizeChangeDia":currentChangeDia="currentChangeDia"
><template #column1><el-table-column label="序号"><template #default="scope"><span>{{ scope.row.createTime }}</span></template></el-table-column></template><template #column2><!-- 你的第二个列定义 --></template>
</ExportRecordsModal>

实现前

 实现后

http://www.lryc.cn/news/351603.html

相关文章:

  • 正则项学习笔记
  • Django自定义模板标签与过滤器
  • k8s集群安装后CoreDNS 启动报错plugin/forward: no nameservers found
  • AI图片过拟合如何处理?答案就在其中!
  • 0基础如何进入IT行业
  • 一键批量提取TXT文档前N行,高效处理海量文本数据,省时省力新方案!
  • Java-常见面试题收集(十六)
  • vue从入门到精通(四):MVVM模型
  • 提供一个c# winform的多语言框架源码,采用json格式作为语言包,使用简单易于管理加载且不卡UI,支持“语言分级”管理
  • Docker常见命令
  • 中科大6系+先研院+中南大学电子信息学院2023年保研经历
  • 分布式理论--BASE
  • 【计算机网络原理】浅谈应用层协议的自定义和传输层UDP协议的总结
  • 正则表达式及其应用
  • VUE面试题(3)--vue常见面试题
  • 2024.05.24|生信早报【AI测试版】
  • 计算机毕业设计 | springboot药品库存追踪与管理系统 药店管理(附源码)
  • Flink 对接 Hudi 查询数据,java代码编写
  • 计算机操作系统总结(1)
  • HTML5好看的通用网站模板源码
  • AWS安全性身份和合规性之Inspector
  • mybatis plus 配置多数据源(数据源进行切换)
  • Docker-Android安卓模拟器本地部署并实现远程开发测试
  • vue-封装上下(垂直方向)轮播
  • 海外私人IP和原生IP有什么区别,谁更有优势?
  • 主流容器工具对比以及重点推荐学习的企业级工具
  • 国产linux系统(银河麒麟,统信uos)使用 PageOffice 国产版在线编辑word文件,同时保存数据和文件
  • 个人感觉对Material设计有用的几个网址
  • ubuntu18 安装sudo
  • 【力扣一轮】202.快乐数 1.两数之和