原因:被合并的单元格未隐藏,才引起后方单元格错位,
隐藏单元格方法:{ rowspan: 0, colspan: 0 };
<template>
<div id="cell_merge">
<el-table :data="tableData" :span-method="objectSpanMethod" border style="width: 100%; margin-top: 20px">
<el-table-column type="index"></el-table-column>
<el-table-column prop="id" label="ID" width="180">
</el-table-column>
<el-table-column prop="name" label="姓名">
</el-table-column>
<el-table-column prop="amount1" label="数值 1(元)">
</el-table-column>
<el-table-column prop="amount2" label="数值 2(元)">
</el-table-column>
<el-table-column prop="amount3" label="数值 3(元)">
</el-table-column>
</el-table>
</div>
</template>
<script>
export default {
data() {
return {
tableData:[],
data: [{
id: '12987122',
name: '王小虎',
amount1: '234',
amount2: '3.2',
amount3: 10
}, {
id: '12987123',
name: '王小虎',
amount1: '165',
amount2: '4.43',
amount3: 12
}, {
id: '12987124',
name: '王小虎',
amount1: '324',
amount2: '1.9',
amount3: 9
}, {
id: '12987125',
name: '王小虎',
amount1: '621',
amount2: '2.2',
amount3: 17
}, {
id: '12987126',
name: '王小虎',
amount1: '539',
amount2: '4.1',
amount3: 15
}]
}
},
methods: {
objectSpanMethod({row,column,rowIndex,columnIndex}) {
if(columnIndex === 1) {
if(rowIndex % 2 === 0) {
return {
rowspan: 2,
colspan: 1
};
} else { // 隐藏单元格,否则单元格会错位,必不可少
return {
rowspan: 0,
colspan: 0
};
}
}
}
},
mounted(){
setTimeout(()=>{
this.tableData =[...this.data] ;
console.log(this.tableData)
},3000)
}
}
</script>
<style>
</style>
此demo代码,这里是指定列,在此列,偶数行合并奇数行,奇数行隐藏,不然就会错位。
注意注释, { rowspan: 0, colspan: 0}用来隐藏单元格。
注意:被合并的那些单元格,必须都得隐藏,否则就会错位
转载,原文链接:https://blog.csdn.net/yiyueqinghui/article/details/95104988