vue3二次封装element-plus表格,slot透传,动态slot。

vue

在一个组件中使用二次封装的表格组件,slot如何透传。

例如:有3个组件,C1,C2,Table,C1组件使用了C2组件,C2组件使用了Table,那么在C1组件中如何把slot透传到Table组件中。

Table组件 Table.vue 在main.js 配置全局组件。

html 复制代码
	<template>
	  <el-table v-bind="$attrs">
	     <template v-for="column in $attrs.columns">
	      <el-table-column v-if="column.slotName" :key="column.prop" v-bind="column">
	        <template #default="scope">
	            <slot :name="column.slotName" v-bind="scope"></slot>
	        </template>
	      </el-table-column>
	      <el-table-column v-else :key="column.prop" v-bind="column" />
	    </template>
	  </el-table>
	 </template>
	 
	 <script setup></script>

C2组件 C2.vue

html 复制代码
	<template>
		<el-card>其他内容</el-card>
		<el-card>
		    <Table v-bind="$attrs">
		      <template
			      v-for="column in $attrs.columns.filter(i => i.slotName)" 
			      :key="column.slotName" 
			      #[column.slotName]="scope">
		        <slot :name="column.slotName" v-bind="scope" />
		      </template>
		     </Table>
		</el-card>
	</template>
	
	<script lang="ts" setup></script>

C1组件 C1.vue

html 复制代码
	<template>
	  <C2 :columns="tableColumns" :data="tableData">
	     <template #status="{row}">
	         <div>
	           <el-tag type="success">{{ row.status }}</el-tag>
	         </div>
	     </template>
	  </C2>
	</template>
	
	<script lang="ts" setup>
	  import { ref } from "vue";

	  const tableData = ref<Array<any>>([
	   {id: 1, name: "JY-SZ-2023", createdtime: "2023-12-31", status: "正常"},
	   {id: 2, name: "VC890D", createdtime: "2024-06-30", status: "正常"}
    ])
	  const tableColumns = [
	      {
		    "label": "ID",
		    "prop": "id",
		  },
		  {
		    "label": "名称",
		    "prop": "name",
		  },
		  {
		    "label": "创建时间",
		    "prop": "createdtime",
		  },
		  {
		    "label": "状态",
		    "prop": "status",
		    "slotName": 'status',
		  }
    ]
  </script>

在C1组件中正常展示tag

相关推荐
程序员码歌44 分钟前
短思考第261天,浪费时间的十个低效行为,看看你中了几个?
前端·ai编程
Swift社区1 小时前
React Navigation 生命周期完整心智模型
前端·react.js·前端框架
若梦plus2 小时前
从微信公众号&小程序的SDK剖析JSBridge
前端
用泥种荷花2 小时前
Python环境安装
前端
Light602 小时前
性能提升 60%:前端性能优化终极指南
前端·性能优化·图片压缩·渲染优化·按需拆包·边缘缓存·ai 自动化
Jimmy2 小时前
年终总结 - 2025 故事集
前端·后端·程序员
烛阴2 小时前
C# 正则表达式(2):Regex 基础语法与常用 API 全解析
前端·正则表达式·c#
roman_日积跬步-终至千里2 小时前
【人工智能导论】02-搜索-高级搜索策略探索篇:从约束满足到博弈搜索
java·前端·人工智能
GIS之路3 小时前
GIS 数据转换:使用 GDAL 将 TXT 转换为 Shp 数据
前端
多看书少吃饭3 小时前
从Vue到Nuxt.js
前端·javascript·vue.js