el-table span-method 与空白单元格合并

el-table span-method 与空白单元格合并

原始excel表格样式:
在这里插入图片描述
页面呈现的表格样式:
在这里插入图片描述

代码如下

// An highlighted block
<el-table :data="showList" :span-method="arraySpanMethod">
   ...
</el-table>

	// 数据处理
	dealData (rowCell) {
	  let indexList= [], locationList = []
	  // 如果单元格不为空,找到对应的index
	  list[1].forEach((item, index) => {if (item[rowCell] != '') {indexList.push(index)}});
	  // 数据最后一项也push进去,用于合并总列数计算
	  indexList.push(list[1].length)
	  // 计算有数据列距下一个有数据列的列数:rowspan
	  indexList.forEach((item, index) => {
	    if (index == indexList.length - 1) return
	    locationList[`'${item}'`] = ({ rowspan: indexList[index + 1] - item, colspan: 1 })
	  })
	  return locationList
	},
	// 单元格合并方法
  	arraySpanMethod ({ row, rowIndex, columnIndex }) {
      if (columnIndex === 1) { // 此处代表我要合并第一列
        if (row.t1 != '') { // 如果此单元格不为空,进行数据处理
          // 处理合并数据
          let locationList = this.dealData('t1')
          return locationList[`'${rowIndex}'`]
        }
        else {  // 为空则隐藏
          return {
            rowspan: 0,
            colspan: 0
          };
        }
      }

欢迎指正,over 😃

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值