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

相关推荐
IT_陈寒11 分钟前
Redis 高并发实战:我从 5000QPS 优化到 5W+ 的7个核心策略
前端·人工智能·后端
vortex531 分钟前
ASP vs ASP.NET vs ASP.NET Core:三代微软 Web 技术核心区别解析
前端·microsoft·asp.net
Apifox40 分钟前
如何在 Apifox 中使用「模块」合理地组织接口
前端·后端·测试
冰暮流星42 分钟前
css之flex属性
前端·css
若安程序开发1 小时前
WEBweb前端OPPO手机商城网站项目
前端·智能手机
范德萨_1 小时前
JavaScript 实用技巧(总结)
开发语言·前端·javascript
李志2781 小时前
初识预加载
javascript
执携1 小时前
Vue Router (匹配当前路由的链接和类名配置)
前端·javascript·vue.js
若安程序开发1 小时前
web华为商城前端项目4页面
前端·华为
一枚前端小能手1 小时前
🏷️ HTML 属性参考 - 常用与全局属性的行为、兼容性与最佳实践
前端·javascript·html