el-table后台接口返回数据动态合并单元格

在实际工作中,通常数据都是后台接口返回的,有时需要对数据进行合并,可利用el-table的span-method方法,结合数据处理,进行合并,如下实例

html 复制代码
<el-table 
    :data="dataTable"
    border
    row-key="id"
    :span-method="objSpanMethod"
></el-table>
javascript 复制代码
// 默认接受的参数{当前行的值,当前列的值,行的下标,列的下标}
// mergeArr:是表格的字段名集合,["name","age","sex"...]
// mergeObj: 是合并信息数据的对象
objSpanMethod({row,column,rowIndex,columnIndex}) {
    // 判断列的属性
    if( mergeArr.indexOf(column.property) !== -1 ) {
        // 判断值是不是为0 
        if (mergeObj[column.property][rowIndex]) {
            return [mergeObj[column.property][rowUndex],1]
        } else {
            // 如果为0,则为需要合并的行
            return [0,0]
        }
    }
}
javascript 复制代码
// 处理数据
getSpanArr(data) {
    mergeArr.forEach((key,index) => {
        // 记录需要合并行的起始位置
        let count = 0
        // 记录每一列的合并信息
        mergeObj[key] = []
        data.forEach((item,index) => {
            // index === 0 表示数据为第一行,直接push一个1
            if (index===0) {
                 mergeObj[key].push(1)
            } else {
                // 判断当前行是否与上一行的值相等,如果相等,在count记录的位置其值+1,表示当前行需要合并push一个0,作为占位
                if (item[key] === data[index-1][key] {
                    mergeObj[key][count] += 1
                    mergeObj[key].push(0)
                } else {
                    count = index
                    mergeObj[key].push(1)
                }
            }
        })
    })
}
相关推荐
姑苏洛言34 分钟前
基于微信公众号小程序的课表管理平台设计与实现
前端·后端
烛阴1 小时前
比UUID更快更小更强大!NanoID唯一ID生成神器全解析
前端·javascript·后端
Alice_hhu1 小时前
ResizeObserver 解决 echarts渲染不出来,内容宽度为 0的问题
前端·javascript·echarts
charlee442 小时前
解决Vditor加载Markdown网页很慢的问题(Vite+JS+Vditor)
javascript·markdown·cdn·vditor
逃逸线LOF2 小时前
CSS之动画(奔跑的熊、两面反转盒子、3D导航栏、旋转木马)
前端·css
老马啸西风3 小时前
工作流引擎-18-开源审批流项目之 plumdo-work 工作流,表单,报表结合的多模块系统
vue.js·开源·activiti·workflow·flowable·oa·bpm
萌萌哒草头将军3 小时前
⚡️Vitest 3.2 发布,测试更高效;🚀Nuxt v4 测试版本发布,焕然一新;🚗Vite7 beta 版发布了
前端
技术小丁3 小时前
使用 HTML + JavaScript 在高德地图上实现物流轨迹跟踪系统
前端·javascript·html
小小小小宇3 小时前
React 并发渲染笔记
前端
stark张宇4 小时前
Web - 面向对象
前端·javascript