循环html向下合并,vue 中 elment-ui table合并上下两行相同数据单元格

html :

:header-cell-style="{background:'#6d7f93',color:'white'}"

:data="ptableDate"

align="center"

border

v-loading="loading"

:height="tableHeight"

:span-method="objectOneMethod"

>

method

objectOneMethod({ row, column, rowIndex, columnIndex }) {

if (columnIndex === 0) {

const _row = this.setTable(this.ptableDate).one[rowIndex];

const _col = _row > 0 ? 1 : 0;

return {

rowspan: _row,

colspan: _col

};

}

if (columnIndex === 1 ) {

const _row = this.setTable(this.ptableDate).two[rowIndex];

const _col = _row > 0 ? 1 : 0;

return {

rowspan: _row,

colspan: _col

};

}

},

setTable(tableData) {

let spanOneArr = [],

spanTwoArr = [],

concatOne = 0,

concatTwo = 0;

tableData.forEach((item, index) => {

if (index === 0) {

spanOneArr.push(1);

spanTwoArr.push(1);

} else {

if (item.projName === tableData[index - 1].projName) {

//第一列需合并相同内容的判断条件

spanOneArr[concatOne] += 1;

spanOneArr.push(0);

} else {

spanOneArr.push(1);

concatOne = index;

}

if (item.dirtySection === tableData[index - 1].dirtySection) {

//第二列和需合并相同内容的判断条件

spanTwoArr[concatTwo] += 1;

spanTwoArr.push(0);

} else {

spanTwoArr.push(1);

concatTwo = index;

}

}

});

return {

one: spanOneArr,

two: spanTwoArr

};

},

ps:下面看下ELEMENT-UI 合并单元格的方法

arraySpanMethod({ row, column, rowIndex, columnIndex }) {

// 只合并区域位置

//columnIndex 横的第一列

//rowIndex 竖的数组的length % 3 ==0 合并单元格

if (columnIndex === 0) { //如果是第一行

if (rowIndex % 3 === 0) {//如果是 数组长度 % 3 ==0

return {

rowspan: 3,

colspan: 1

};

} else {

return {

rowspan: 0,

colspan: 0

};

}

}

},

6eb75ea7abed29769f6117de34ebfa9f.png

总结

以上所述是小编给大家介绍的vue 中 elment-ui table合并上下两行相同数据单元格,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

时间: 2019-12-23

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值