elementui <el-table> 单元格合并

文章介绍了如何在ElementUI中自定义封装单元格,包括定义合并列的规则、合并逻辑函数以及合并方法,展示了如何根据特定条件实现单元格的合并。
摘要由CSDN通过智能技术生成

问题:elementui 原生单元格样例复杂,所以自己封装实现

效果如下:在这里插入图片描述

代码如下:

  1. 定义合并列规则

spanRule: {
          1: ['sourceId', 'prod', 'countries'],
        },
  1. 合并逻辑

  function filterArray(item) {
    const valueArray = this.rule.filter((prop) => {
      return item[prop] === this.data[prop];
    });
    if (valueArray.length === this.rule.length) {
      return true;
    } else {
      return false;
    }
  }
  1. 合并方法

      objectSpanMethod({ row, column, rowIndex, columnIndex }) {
        if (Object.keys(this.spanRule).includes(columnIndex.toString())) {
          // filter验证数组
          const currentTable = {
            rule: this.spanRule[columnIndex],
            data: this.list[rowIndex],
          }; // 该单元格是否被合并 true 合并, false : 不合并
          let chooseSpan = false;
          if (rowIndex !== 0) {
            chooseSpan = filterArray.call(currentTable, this.list[rowIndex - 1]);
          }
          if (chooseSpan) {
            return { rowspan: 0, colspan: 1 };
          } else {
            return {
              rowspan: this.list.filter(filterArray, currentTable).length,
              colspan: 1,
            };
          }
        }
        return { rowspan: 1, colspan: 1 };
      },
  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值