vue3 + Ant Design 实现双表头表格的效果(横向表头+纵向表头)

 更新时间:2023年12月25日 10:13:55   作者:十五圆  
这篇文章主要介绍了vue3 + Ant Design 实现双表头表格(横向表头+纵向表头),需要的朋友可以参考下

一、要实现的效果(纵向固定表头的表格,横向表头数量动态化)

二、这是后台返回的数据格式(以企业为数组,每个企业里有个站点数组pointFactors)

三、代码实现步骤

(1)定义纵向固定表头

// 纵向表头数组 tableColumns
const tableColumns = ref([
  {
    label: "日(24小时)数据浓度均值",
    value: "monthMaxDayValue",
  },
  {
    label: "小时数据平均浓度均值",
    value: "monthHourValue",
  },
]);

(2)动态生成横向表头(从接口获取数据)

//定义横向表头列 columns
 const columns = ref([]);
//定义表格数据
 const list = ref([]);
 // 先添加第一列
 columns.value = [
      {
        title: "",
        dataIndex: "timeType",
        width: 190,
       fixed: "left",
     },
  ];
//处理接口返回的数据data,动态拼接表头数组 columns
data.forEach(item => {
     const obj = {
        id: item.enterpriseId,
        parentId: null,
        title: item.enterpriseName,
        align: "center",
        children: [],
      };
      if (item.pointFactors.length) {
          item.pointFactors.forEach(element => {
              list.push({
                name: element.pointName,
                id: element.pointId,
                monthMaxDayValue: element.monthMaxDayValue,
                monthHourValue: element.monthHourValue,
              });
              const childObj = {
                id: element.pointId,
                parentId: item.enterpriseId,
                title: element.pointName,
                width: 130,
                align: "center",
                dataIndex: element.pointId,
                customRender: ({ record }) => {
                  return record[element.pointId]
                    ? record[element.pointId]
                    : "-";
                },
              };
              obj.children.push(childObj);
          });
     }
     columns.value.push(obj);
});

(3)循环原始数据,生成组件需要的横向数据

// tableColums  已定义的纵向表头
// tableData   已定义的表格数组
 for (const tab of tableColumns.value) {
     const col: any = Object.create(null);
     list.forEach((item, index) => {
         col.timeType = tab.label;
         col[list[index + 0].id] = item[tab.value];
     });
     tableData.value.push(col);
}

(4)数据带入表格组件中

<a-table
     :columns="columns"
     :data-source="tableData"
     :pagination="false"
     row-key="id"
     bordered
 />

到此这篇关于vue3 + Ant Design 实现双表头表格(横向表头+纵向表头)的文章就介绍到这了,更多相关vue Ant Design双表头表格内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue+echarts绘制省份地图并添加自定义标注方式

    vue+echarts绘制省份地图并添加自定义标注方式

    这篇文章主要介绍了vue+echarts绘制省份地图并添加自定义标注方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • 解决Vue项目中tff报错的问题

    解决Vue项目中tff报错的问题

    这篇文章主要介绍了解决Vue项目中tff报错的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-10-10
  • Vue面试题及Vue知识点整理

    Vue面试题及Vue知识点整理

    这篇文章主要介绍了Vue面试题及Vue知识点整理,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友参考下吧
    2018-10-10
  • flutter使用tauri实现一个一键视频转4K软件

    flutter使用tauri实现一个一键视频转4K软件

    这篇文章主要为大家介绍了flutter使用tauri实现一个一键视频转4K软件详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • Vue通过懒加载提升页面响应速度

    Vue通过懒加载提升页面响应速度

    这篇文章主要介绍了Vue通过懒加载提升页面响应速度,对Vue性能感兴趣的同学,可以参考下
    2021-05-05
  • vue中给el-radio添加tooltip并实现点击跳转方式

    vue中给el-radio添加tooltip并实现点击跳转方式

    这篇文章主要介绍了vue中给el-radio添加tooltip并实现点击跳转方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • 基于Vue3+IntersectionObserver实现高性能图片懒加载

    基于Vue3+IntersectionObserver实现高性能图片懒加载

    本文详解 Vue3 中如何使用 IntersectionObserver API 实现图片懒加载,核心优势在于进入视口才加载图片,可显著提升首屏加载速度、节省带宽资源、避免页面卡顿,适合多图列表场景,需要的朋友可以参考下
    2026-05-05
  • vue验证码(identify)插件使用方法详解

    vue验证码(identify)插件使用方法详解

    这篇文章主要为大家详细介绍了vue验证码插件使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • 解决vue3中内存泄漏的问题

    解决vue3中内存泄漏的问题

    在项目中会发现一个奇怪的现象,当我们在使用element-plus中的图标组件时会出现内存泄漏,所以本文讲给大家讲讲如何解决vue3中的内存泄漏的问题,需要的朋友可以参考下
    2023-07-07
  • 手写Vue弹窗Modal的实现代码

    手写Vue弹窗Modal的实现代码

    这篇文章主要介绍了手写Vue弹窗Modal的实现代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09

最新评论