el-table 扁平化数据后合并单元格

原始数据:

javascript 复制代码
<script setup>

 // 原始数据: 
const preOrderProInfoList ref([
        {
            "PRO_NO": "154685",
            "PRE_PRO_NO": 2303,
            "orders": [
                {
                    "ORDER_NO": "25B00190",
                    "SEND_CENTER_SEQ": 1,
                    "REQ_DVS_CD": "2",
                    "DLVR_WAY_CD": "001",
                    "WARE_STATE_CD": "001",
                    "order_type": "1",
                    "request_type": "0"
                },
                {
                    "ORDER_NO": "25B00189",
                    "SEND_CENTER_SEQ": 1,
                    "REQ_DVS_CD": "2",
                    "DLVR_WAY_CD": "001",
                    "WARE_STATE_CD": "001",
                    "order_type": "1",
                    "request_type": "0"
                }
            ]
        }])



// 扁平化 
// 扁平化后的组合数据
const processedTableData = computed(() =>
    preOrderProInfoList.value.flatMap(combo =>
        combo.orders.map(product => ({
            ...product,
            PRO_NO: combo.PRO_NO,
            PRE_PRO_NO: combo.PRE_PRO_NO,
            PRO_IMG: combo.PRO_IMG || 'https://q7.itc.cn/q_70/images03/20241204/9442f197bdc94c05a32e7ed8b719dd59.jpeg'

        }))
    )
)


const arraySpanMethod = ({ row, rowIndex, columnIndex }) => {
    if ([0, 1].includes(columnIndex)) {
        const list = processedTableData.value
        if (
            rowIndex === 0 ||
            list[rowIndex].PRO_NO !== list[rowIndex - 1].PRO_NO
        ) {
            let rowspan = 1
            for (
                let i = rowIndex + 1;
                i < list.length && list[i].PRO_NO === row.PRO_NO;
                i++
            ) {
                rowspan++
            }
            return { rowspan, colspan: 1 }
        }
        // 合并到上面
        return { rowspan: 0, colspan: 0 }
    }
    // 其他列正常显示
    return { rowspan: 1, colspan: 1 }
}

< /script>
javascript 复制代码
<template>   
<el-table :data="processedTableData" border :span-method="arraySpanMethod" style="width: 100%"
                :cell-style="{ 'text-align': 'center' }" :header-cell-style="{
                    background: '#5f697d',
                    color: '#fff',
                    height: '10px',
                    width: '90%',
                    'text-align': 'center'
                }">
                <!-- 商品图片/编号 -->
                <el-table-column prop="PRO_NO" width="100">
                    <template #header>
                        <div class="label-flex">
                            <div>{{ t('product.商品图片') }}</div>
                            <div>{{ t('order_list.商品编号') }}</div>
                        </div>
                    </template>
                    <template #default="{ row }">
                        <div class="product-cell">
                            <el-image :src="row.PRO_IMG" class="product-img" />
                            <div class="product-info">
                                {{ row.PRO_NO }}
                            </div>
                        </div>
                    </template>
                </el-table-column>

                <!-- 代买商品编号 -->
                <el-table-column prop="PRE_PRO_NO" :label="t('errorInStock.代买商品编号')" width="150">
                    <template #default="{ row }">
                        <div v-if="row.showProductInfo">
                            {{ row.PRE_PRO_NO }}
                        </div>
                    </template>
                </el-table-column>

                <!-- 订单编号 -->
                <el-table-column :label="t('order_list.订单号')" width="180">
                    <template #default="{ row }">
                        <div class="order-item">
                            <el-radio v-model="selectedOrders[row.PRO_NO]" :label="row.ORDER_NO"
                                @change="handleOrderChange(row)">
                                {{ row.ORDER_NO }}
                            </el-radio>
                        </div>
                    </template>
                </el-table-column>
  </el-table>
相关推荐
蚰蜒螟6 小时前
深入 Linux 内核同步机制:从 futex 到 spinlock 的完整旅程
linux·windows·microsoft
dllmayday7 小时前
Linux 上用终端连接 WiFi
linux·服务器·windows
Curtain_Gin13 小时前
windows nvim lazy
windows
生而为虫15 小时前
Claude Code 最新版安装教程(Windows/Mac/Linux 全平台) 面向普通用户的 Claude Code 安装与模型接入指南
linux·windows·macos
DevilSeagull15 小时前
Windows 批处理 (Batch) 编程: 从入门到入土. (一) 基础概念与环境配置
开发语言·windows·后端·batch·语言
CyL_Cly16 小时前
Parsec(parsec安卓/windows/macos下载)
windows
2601_9583205717 小时前
【小白零基础上手 】钉钉内部机器人接入 OpenClaw 完整流程讲解(含安装包)
人工智能·windows·机器人·钉钉·open claw·open claw安装
love530love18 小时前
f2 项目(多平台的作品下载与接口数据处理)源码部署记录
人工智能·windows·f2
生而为虫18 小时前
在VScode中使用Claude Code agent并配置模型(仅mac电脑实际操作,windows电脑未实际操作如有问题可留言)
windows·vscode·macos
叶小鸡18 小时前
Java 篇-项目实战-天机学堂(从0到1)-day10
windows·microsoft