elementUI中的 table实现表格内相同列树形合并且统计数值

本文展示了如何使用ElementUI中的el-table组件实现表格数据加载,并展示了一种方法来动态合并指定列(如工程名称和人员数量)以展示相关统计信息。
摘要由CSDN通过智能技术生成

效果如下实现表格内相同列合并统计

直接上代码

template

   <el-table v-loading="listLoading" align="center" border :data="tableList" :span-method="objectSpanMethod">
      <el-table-column v-for="(item, index) in tableCom" :key="index" align="center" :label="item.label" :min-width="100" :prop="item.prop">
        <template slot-scope="scope">
          <div v-if="index === 2" class="inlinListMain">
            <div v-for="item2 in scope.row.dataInfo" :key="item2.activityType" class="inlinList">{{ item2.activityTypeName }}</div>
          </div>
          <div v-if="index === 3" class="inlinListMain">
            <div v-for="(item2, index2) in scope.row.dataInfo" :key="index2" class="inlinList">{{ item2.count }}</div>
          </div>
          <span v-else>{{ scope.row[item.prop] }}</span>
        </template>
      </el-table-column>
    </el-table>

data

data(){
return{
    tableList: [],//表格数据,数据为接口获取
        tableCom: [
          { label: '工程名称', prop: 'projectName' },
          { label: '标段', prop: 'segmentName' },
          { label: '人员类别', prop: 'activityTypeName' },
          { label: '人员数量', prop: 'count' },
          { label: '合计', prop: 'total' },
        ],//表格标题
        mergeObj: {},//合并列需要的存储对象
        mergeArr: ['projectName'],//需要合并的对象(tableList里的某个属性)
        sameObjIndex: 0,//合并统计
        sameObj: {},
}
}

methods

 // 处理表格数据(合并行)
      objectSpanMethod({ row, column, rowIndex, columnIndex }) {
        // 判断列的属性
        if (this.mergeArr.indexOf(column.property) !== -1) {
          // 判断其值是不是为0
          if (this.mergeObj[column.property][rowIndex]) {
            return [this.mergeObj[column.property][rowIndex], 1]
          } else {
            // 如果为0则为需要合并的行
            return [0, 0]
          }
        }
      },
      // getSpanArr方法
      getSpanArr(data) {
        this.mergeArr.forEach((key, index1) => {
          let count = 0 // 用来记录需要合并行的起始位置
          this.mergeObj[key] = [] // 记录每一列的合并信息
          data.forEach((item, index) => {
            // index == 0表示数据为第一行,直接 push 一个 1
            if (index === 0) {
              this.mergeObj[key].push(1)
              this.sameObj[this.sameObjIndex] = item.count
            } else {
              // 判断当前行是否与上一行其值相等 如果相等 在 count 记录的位置其值 +1 表示当前行需要合并 并push 一个 0 作为占位
              if (item[key] === data[index - 1][key]) {
                this.mergeObj[key][count] += 1
                this.mergeObj[key].push(0)
                this.sameObj[this.sameObjIndex] += item.count
              } else {
                // 如果当前行和上一行其值不相等
                count = index // 记录当前位置
                this.mergeObj[key].push(1) // 重新push 一个 1
                this.sameObjIndex++
                this.sameObj[this.sameObjIndex] = 0
                // this.sameObj[this.sameObjIndex] = item.count
              }
            }
          })
        })
      },

在初始化完成tableList表格数据后,调用this.getSpanArr(this.tableList)即可

需要注意的是,因为数据结构的不同,在合并的时候需要区分具体的某些字段

css

    .el-table .cell {
      padding-left: 0 !important;
      padding-right: 0 !important;
    }
    .el-table--small .el-table__cell {
      padding: 0 !important;
    }
    .el-table__header-wrapper .el-table__cell {
      padding: 8px !important;
    }
    .inlinList {
      padding: 10px 0;
      border-bottom: 1px solid #e7e5e5;
    }
    .inlinListMain .inlinList:last-child {
      border-bottom: none;
    }

因为element ui自带的样式限制,在更改样式的时候,最好在前面加一个类,用style lang=“scss”

  • 10
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现 element-ui table 合并第二相同数据,需要使用 `span-method` 属性和 `Table-column` 的 `prop` 属性。 首先,在 `Table` 组件,使用 `span-method` 属性来定义合并规则: ```html <el-table :data="tableData" :span-method="mergeRows"> ... </el-table> ``` 然后,在 `methods` 定义合并规则,可以使用 `row` 和 `column` 参数来获取当前单元格的行和信息,进而判断是否需要合并。 ```javascript methods: { mergeRows(row, column, rowIndex, columnIndex) { if (columnIndex === 1) { // 判断当前是否为第二 const rowSpan = this.getRowSpan(row, column, rowIndex, columnIndex); if (rowSpan === 1) { // 如果当前单元格不需要合并,返回 { rowspan: 1, colspan: 1 } return { rowspan: 1, colspan: 1 }; } else { // 如果当前单元格需要合并,返回 { rowspan: rowSpan, colspan: 1 } return { rowspan: rowSpan, colspan: 1 }; } } }, getRowSpan(row, column, rowIndex, columnIndex) { // 获取当前单元格的值 const currentValue = row[column.property]; // 定义合并行数 let rowSpan = 1; // 遍历当前的上方单元格 for (let i = rowIndex - 1; i >= 0; i--) { const prevRow = this.tableData[i]; // 如果上方单元格的值与当前单元格的值相等,行数加一 if (prevRow[column.property] === currentValue) { rowSpan++; } else { // 如果上方单元格的值与当前单元格的值不相等,停止遍历 break; } } return rowSpan; } } ``` 上面的代码,`getRowSpan` 方法用来获取当前单元格需要合并的行数,遍历当前的上方单元格,如果上方单元格的值与当前单元格的值相等,则行数加一。最后,返回合并后的行数。 最后,还需要在第二的 `Table-column` 设置 `prop` 属性,表示该数据源来自于表格数据的哪个字段。 ```html <el-table-column label="第二" prop="column2" /> ``` 这样,就可以实现 element-ui table 合并第二相同数据了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值