需求:按照数据的id进行行合并

image.png

首先---查看文档

需要用到的api: 合并行或列的计算方法 Function({ row, column, rowIndex, columnIndex })

参数 说明 类型
span-method 合并行或列的计算方法 Function({ row, column, rowIndex, columnIndex })
cell-mouse-enter 当单元格 hover 进入时会触发该事件 row, column, cell, event
cell-mouse-leave 当单元格 hover 退出时会触发该事件 row, column, cell, event
row-class-name 行的 className 的回调方法,也可以使用字符串为所有行设置一个固定的 className。 Function({row, rowIndex})/String

行合并方法

这里根据数据的id是否相同进行合并,把相同id的数据对应的行号放到一个数组里面然后以id为key,行号数组为value进行存储

  private OrderIndexArr: { [key: string]: number[] } = {};

  private rowIndex = '-1';

  private hoverOrderArr: number[] = [];

  // 封装表格数据---按照某一列进行合并
  private getDatalistCaculate() {
    const orderObj: { [key: string]: number[] } = {};
    this.projectLists.forEach(
      (element: ProjectManageModule.ProjectInfo, index: number) => {
        const id = element.id || '';
        if (orderObj[id]) {
          orderObj[id].push(index);
        } else {
          orderObj[id] = [];
          orderObj[id].push(index);
        }
      }
    );
    this.OrderIndexArr = orderObj;
  }

  // 合并单元格
  objectSpanMethod({
    row,
    column,
    rowIndex,
    columnIndex
  }: {
    row: ProjectManageModule.ProjectInfo;
    column: { [key: string]: any };
    rowIndex: number;
    columnIndex: number;
  }) {
    if (columnIndex === 0) {
      // 如果当前行与上一行id这个字段一样
      if (rowIndex > 0 && row.id === this.projectLists[rowIndex - 1].id) {
        return {
          rowspan: 0,
          colspan: 0
        };
      } else {
        const id = row.id || '';
        const rows: number[] = this.OrderIndexArr[id];
        const length = rows.length;
        return {
          rowspan: length,
          colspan: 1
        };
      }
    }
  }

解决鼠标悬浮表格样式问题

当有超过两行数据合并后鼠标悬浮上去会发现不是合并的行处于active状态而是当读一行一行悬浮后才会处于active状态,这样看上去会非常别扭。这里api的处理逻辑就是鼠标进入事件判断当前行是否为合并行,如果是的话就把他的一起合并的行添加一个类名然后添加背景颜色。


  // 添加类名
  private rowClassName({
    row,
    rowIndex
  }: {
    row: ProjectManageModule.ProjectInfo;
    rowIndex: number;
  }) {
    const rows: number[] = this.hoverOrderArr;
    if (rows.includes(rowIndex)) {
      return 'success-row';
    }
  }

  // 鼠标悬浮行
  private cellMouseEnter(row: any, column: any, cell: any, event: any) {
    this.rowIndex = row.rowIndex + '';
    this.hoverOrderArr = [];
    for (const key in this.OrderIndexArr) {
      if (key === row.id) {
        this.hoverOrderArr = this.OrderIndexArr[row.id];
      }
    }
  }

  private cellMouseLeave(row: any, column: any, cell: any, event: any) {
    this.rowIndex = '-1';
  }
<style lang="less">
.el-table .success-row {
  background: #f5f7fa;
}
</style>

如果觉得文章还不错可以关注我的博客


wzp123321
17 声望3 粉丝