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

在一个组件中使用二次封装的表格组件,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

相关推荐
jiayong235 分钟前
Vue2 与 Vue3 核心原理对比 - 面试宝典
vue.js·面试·职场和发展
有诺千金14 分钟前
VUE3入门很简单(4)---组件通信(props)
前端·javascript·vue.js
2501_9447114315 分钟前
Vue-路由懒加载与组件懒加载
前端·javascript·vue.js
雨季66640 分钟前
Flutter 三端应用实战:OpenHarmony “心流之泉”——在碎片洪流中,为你筑一眼专注的清泉
开发语言·前端·flutter·交互
换日线°44 分钟前
前端3D炫酷展开效果
前端·3d
广州华水科技1 小时前
大坝变形监测的单北斗GNSS技术应用与发展分析
前端
Dontla1 小时前
浏览器localStorage共享机制介绍(持久化客户端存储方案)本地存储冲突、iframe、XSS漏洞、命名空间隔离
前端·网络·xss
霍理迪1 小时前
JS其他常用内置对象
开发语言·前端·javascript
tao3556671 小时前
HTML-03-HTML 语义化标签
前端·html
小马_xiaoen1 小时前
IndexedDB 从入门到实战:前端本地大容量存储解决方案。
前端