antd table 表格动态合并单元格

Ant Design of Vue表格动态合并单元格

需求

最近在做一个功能,需要在表格内展示数据,动态合并值相同单元格,大概是下图的样子
在这里插入图片描述
百度的解决方案基本都是比较上下数据是否一致来决定是否合并,当遇到null值或数据中有不连续但是重复数据是会出问题,导致表格单元格不渲染或多渲染,修改一下算法在此记录

修改后遇到null后单元格内为空,不会错位,且分页不会出现问题

版本

Ant Design版本 1.5.0
官方文档的合并单元格演示
https://www.antdv.com/components/table-cn/#components-table-demo-colspan-and-rowspan

实现

tableColumns: [{
  title: '第一列',
  dataIndex: 'num',
  customRender: (text, record, index) => {
    const obj = {
      children: text !== null ? text : '',
      attrs: {}
    }
    obj.attrs.rowSpan = this.mergeCells(text, this.tableData, 'num', index)
    return obj
  }
}, {
  title: '第二列',
  dataIndex: 'name',
  customRender: (text, record, index) => {
    const obj = {
      children: text !== null ? text : '',
      attrs: {}
    }
    obj.attrs.rowSpan = this.mergeCells(text, this.tableData, 'name', index)
    return obj
  }
}]


/**
  * 单元格合并处理
  * @param text 当前单元格的值
  * @param data 当前分页所有数据
  * @param key 当前列的dataIndex
  * @param index 当前数据所在下标
  * @returns {number} 待合并单元格数量
  */
 mergeCells(text, data, key, index) {
   // 上一行该列数据是否一样
   if (index !== 0 && text === data[index - 1][key]) {
     return 0
   }
   let rowSpan = 1
   // 判断下一行是否相等
   for (let i = index + 1; i < data.length; i++) {
     if (text !== data[i][key]) {
       break
     }
     rowSpan++
   }
   return rowSpan
 }

抱歉完整源代码不能贴出来,基本处理方式都在这里了,下面是我的最终处理结果
在这里插入图片描述

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值