在 Element Plus 的 el-table 组件中,可以使用 span-method
属性来动态合并不规律数量的行。您可以根据数据的特定条件来确定合并行的方式
<template>
<el-table :data="tableData" :span-method="handleSpanMethod" border>
<el-table-column type="index" label="序号"></el-table-column>
<el-table-column label="姓名" prop="name"></el-table-column>
<el-table-column label="年龄" prop="age"></el-table-column>
<el-table-column label="性别" prop="gender"></el-table-column>
</el-table>
</template>
<script>
export default {
data() {
return {
tableData: [
{ name: 'John', age: 20, gender: 'Male' },
{ name: 'Jane', age: 30, gender: 'Female' },
{ name: 'Tom', age: 35, gender: 'Male' },
{ name: 'Alice', age: 25, gender: 'Female' },
{ name: 'Bob', age: 28, gender: 'Male' },
{ name: 'Eve', age: 38, gender: 'Female' },
{ name: 'Mike', age: 40, gender: 'Male' },
{ name: 'Lily', age: 42, gender: 'Female' }
]
};
},
methods: {
handleSpanMethod({ row, column, rowIndex, columnIndex }) {
if (columnIndex === 0) {
// 合并姓名列
if (rowIndex > 0 && row.name === this.tableData[rowIndex - 1].name) {
// 当前行的姓名与前一行相同,则合并行
return { rowspan: 0, colspan: 0 };
} else {
// 当前行的姓名与前一行不同,则不合并行
let count = 1;
for (let i = rowIndex + 1; i < this.tableData.length; i++) {
if (this.tableData[i].name === row.name) {
count++;
} else {
break;
}
}
return { rowspan: count, colspan: 1 };
}
} else {
// 其他列不合并
return { rowspan: 1, colspan: 1 };
}
}
}
};
</script>
我们在 el-table 上指定了 span-method
属性,并将其绑定到 handleSpanMethod
方法上。在 handleSpanMethod
方法中,我们根据行索引和列索引来判断是否需要合并行,并返回相应的 rowspan
和 colspan
值。
在这个例子中,我们合并了第一列(姓名列)的行。第一行合并了三行,第四行合并了两行,其余行都不需要合并。其他列不进行合并,每行都显示单个单元格。