element-plus表格,多样本比较,动态渲染表头

问题:

公司给了个excel表格,让比较两个样本之间的数据,并且动态渲染,搞了半天没搞出来,最后让大佬解决了,特此写篇博客记录一下。

我之前的思路是合并行,大概效果是这样:

但是最终的效果有点糟糕, 主要原因还是脑袋转不过弯弯,只想着怎么把数据展示出来,忘记了,其实数据也是可以拆开拼装起来的,特此记录一下自己的小错误。

之前数据如下,之前直接获取index然后合并两个两个row合并,这样写出来的效果有点差强人意

复制代码
 [
  {
    sample: "sample1",
    a: "aaa1",
    b: "b1"
  },
  {
    sample: "sample1",
    a: "aaa2",
    b: "b2"
  },
  {
    sample: "sample2",
    a: "aaa1",
    b: "b1"
  },
  {
    sample: "sample2",
    a: "aaa2",
    b: "b2"
  },
]

解决方案:

在查看了同事写的代码之后,发现数据其实这样展示更加合理

使用element-plus的多级表头来对一些复杂的数据结构进行展示,是element-plus所推荐的,

代码如下:

复制代码
    <el-table :data="tableData" style="width: 50%">
      <el-table-column
        v-for="(item, index) in title"
        :key="index"
        :prop="item.prop"
        :label="item.label"
      >
        <template v-if="item.children">
          <el-table-column
            v-for="(childColumn, childIndex) in item.children"
            :key="childIndex"
            :prop="childColumn.prop"
            :label="childColumn.label"
          >
          </el-table-column>
        </template>
      </el-table-column>
    </el-table>

// 数据
const tableData = [
  {
    Type: "A1",
    "sample1 a": "1",
    "sample1 b": "2",
    "sample2 a": "3",
    "sample2 b": "4",
  },
  {
    Type: "A2",
    "sample1 a": "1",
    "sample1 b": "2",
    "sample2 a": "3",
    "sample2 b": "4",
  },
];

const title = [
  {
    prop: "Type",
    label: "type",
  },
  {
    label: "sample1",
    children: [
      {
        prop: "sample1 a",
        label: "a",
      },
      {
        prop: "sample1 b",
        label: "b",
      },
    ],
  },
  {
    label: "sample12",
    children: [
      {
        prop: "sample2 a",
        label: "a",
      },
      {
        prop: "sample2 b",
        label: "b",
      },
    ],
  },
];

前端获取表头数据,与表格内容数据,就能动态渲染一张样本比较表;

学习与改进:

当然,这样就可以合理展示出对比表格的数据了,但学习了同事的代码,我发现他使用的

h() 进行的动态渲染,看上去就比我的代码要高级一个档次,这里特地贴出来,和大家共同学习一下。

效果图:

复制代码
<script lang="ts">
import { h } from "vue";
export default {
  props: ["columns_data", "columns"],
  setup(props) {
    const createColumns = (columns) => {
      if (!columns.length) return undefined;
      return columns.map((column) => {
        return h(
          ElTableColumn,
          { prop: column.prop, label: column.label },
          column.childColumns
            ? { default: () => createColumns(column.childColumns) }
            : undefined,
        );
      });
    };
    return () => {
      return h(
        ElTable,
        {
          data: props.columns_data,
          border: true,
          height: "100%",
        },
        () => createColumns(props.columns),
      );
    };
  },
};
</script>
相关推荐
晚风吹人醒.3 分钟前
Linux系统安全及应用(账号权限管理、登录控制、弱口令、端口扫描)
linux·运维·系统安全·grub·sudo·账号管理
躲在云朵里`11 分钟前
Linux环境下部署SpringBoot前后端分离项目
linux·服务器
llilian_1612 分钟前
时间同步校时服务器配件清单及挑选攻略 校时时间服务器 网络时间同步装置
运维·服务器·网络
oMcLin13 分钟前
如何在Ubuntu 20.04系统的香港服务器上使用Docker搭建高效的CI/CD流水线并集成Kubernetes?
服务器·ubuntu·docker
nvd1119 分钟前
通过 Gmail API 发送邮件的完整指南
服务器·网络
深圳市恒讯科技21 分钟前
防止服务器被黑:终极防范网络攻击指南
运维·服务器·网络安全
VicdorLin21 分钟前
docker报错: client version 1.24 is too old. Minimum supported API version is 1.44
运维·docker·容器
橘颂TA23 分钟前
【Linux】从 “抢资源” 到 “优雅控场”:Linux 互斥锁的原理与 C++ RAII 封装实战(Ⅰ)
linux·运维·服务器·c++·算法
RisunJan24 分钟前
Linux命令-init命令(管理运行级别和控制系统状态)
linux·运维·服务器
ayaya_mana24 分钟前
Chrony:通用-替换国内 NTP 源进行时间同步
linux·运维·服务器·chrony