vue3+ts+el-table,使用expand实现嵌套表格,如何实现子表格不随主表格滚动?
在Vue 3和Element Plus中,如果你想要实现嵌套表格,并且子表格不随主表格滚动,你可以通过使用CSS样式来实现。
以下是一个简单的例子,展示如何在Vue 3和TypeScript中使用Element Plus的el-table
组件实现嵌套表格,并确保子表格不随主表格滚动:
<template>
<el-table
:data="tableData"
style="width: 100%; overflow: auto;"
>
<el-table-column type="expand">
<template #default="{ row }">
<el-table
:data="row.children"
border
:style="{ position: 'absolute', top: '0', width: '100%' }"
>
<!-- 子表格的列 -->
<el-table-column
v-for="(item, index) in columns"
:key="index"
:prop="item.prop"
:label="item.label"
></el-table-column>
</el-table>
</template>
</el-table-column>
<!-- 主表格的列 -->
<el-table-column
v-for="(item, index) in columns"
:key="index"
:prop="item.prop"
:label="item.label"
></el-table-column>
</el-table>
</template>
<script lang="ts">
import { defineComponent, reactive } from 'vue';
interface TableData {
id: number;
name: string;
children: any[];
}
export default defineComponent({
setup() {
const columns = reactive([
{ label: 'ID', prop: 'id' },
{ label: 'Name', prop: 'name' },
]);
const tableData = reactive<TableData[]>([
{
id: 1,
name: 'Parent 1',
children: [
{ id: 11, name: 'Child 11' },
{ id: 12, name: 'Child 12' },
],
},
// ...更多数据
]);
return {
columns,
tableData,
};
},
});
</script>
<style>
/* 确保子表格位于主表格之上 */
.el-table__expand-icon {
z-index: 1 !important;
}
</style>
在这个例子中,我们定义了一个带有嵌套表格的Vue 3组件。主表格中的每一行都可以展开,显示其子表格。子表格通过设置position: absolute
和top: 0
,使其位于主表格的上方,并且不会随着主表格的滚动而移动。通过CSS样式.el-table__expand-icon
,我们确保了点击展开按钮时,子表格能正确显示在相应行上方。
评论已关闭