elemnt-ui的el-table在table中合并某个字段相同的项(vue3)

1、el-table添加span-method

<el-table :data="table_data" id="out-table" :span-method="objectSpanMethod" style="width: 100%">
...
</el-table>

2、合并的方法

  const objectSpanMethod = ({ row, column, rowIndex, columnIndex }) => {

      if (columnIndex === 1) {

        const _row = flitterData(state.tableData.records).one[rowIndex]

        return {

        rowspan: _row,

        colspan: 1,

        }

      }

    }

    const flitterData = (arr)=>{

      let spanOneArr = [],

        spanTwoArr = [],

        concatOne = 0

        arr.forEach((item, index) => {

          if (index === 0) {

          spanOneArr.push(1)

          spanTwoArr.push(1)

          } else {

          // 只需要将 span_name 修改为自己需要合并的字段名即可

          if (item.districtTeamName === arr[index - 1].districtTeamName) {

            //第一列需合并相同内容的判断条件

            spanOneArr[concatOne] += 1

            spanOneArr.push(0)

          } else {

            spanOneArr.push(1)

            concatOne = index

          }

          }

        })

      return {

        one: spanOneArr,

      }

    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ovideooos

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值