IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue table动态表头数据处理 -> 正文阅读

[JavaScript知识库]vue table动态表头数据处理

table动态表头数据处理经常用到,记录下来方便以后查阅

1、data中定义表头和表格数据:

tableData: [], //表格数据
headerTeamList: [] //表头数据

2、接口获取表头数据:

getHeaderList () {
    serviceApi.getHeaderList().then(res => {
        this.headerTeamList = res.data
    })
}

3、获取table表格数据并处理结果:

getTeamGeneralList () {
  params = {
    startTime: startTime,
    endTime: endTime,
    pageNo: this.pagination.pageNo,
    pageSize: this.pagination.pageSize
  }
  serviceApi.getTeamGeneralList(params).then(res => {
    this.tableData = res.data.list
    this.pagination.total = res.data.total
    if (this.tableData && this.tableData.length > 0) {
      this.tableData.forEach(item => {
        if (item.teamList && item.teamList.length > 0) {
          item.teamList.forEach(team => {
            this.headerTeamList.forEach(list => {
              if (team.teamId === list.teamId) {
                item[team.teamId + 'addNum'] = team.addNum
                item[team.teamId + 'subtractNum'] = team.subtractNum
                item[team.teamId + 'zs'] = team.zs
              }
            })
          })
        }
      })
    }
  })
}

4、布局中使用:

<el-table
  height="450"
  :data="tableData"
  border
  force-scroll="horizontal"
  style="width: 100%">
  <el-table-column prop="dutyTime" label="日期" width="150"></el-table-column>
  <el-table-column v-for="item in headerTeamList" :key="item.teamId" :label="item.teamName" width="300">
    <el-table-column :prop="item.teamId + 'addNum'" label="加分" width="100"></el-table-column>
    <el-table-column :prop="item.teamId + 'subtractNum'" label="扣分" width="100"></el-table-column>
    <el-table-column :prop="item.teamId + 'zs'" label="合计" width="100"></el-table-column>
  </el-table-column>
</el-table>

5、表头数据:

{
  "code": "0",
  "msg": "请求成功",
  "data": [
    {
      "teamId": "229287cc74644db79a190b00a5f6d547",
      "teamName": "战队测试名"
    },
    {
      "teamId": "c1488cf39d3a4c24acc6876dc2ffcb83",
      "teamName": "雄鹰战队"
    },
    {
      "teamId": "d388cbc756894a0bb9fb6c8f7d68ffbf",
      "teamName": "测试战队"
    },
    {
      "teamId": "354cca6e345446e8a941c2b5a26e6b49",
      "teamName": "123"
    },
    {
      "teamId": "5044a1df115e428caf8f3f309b292208",
      "teamName": "关城片区"
    }
  ]
}

6、表格数据:

{
  "code": "0",
  "msg": "请求成功",
  "data": {
    "pageNo": 1,
    "pageSize": 10,
    "list": [
      {
        "dutyTime": "2022-03-01",
        "teamList": [
          {
            "teamName": "雄鹰战队",
            "addNum": "2.0",
            "teamId": "c1488cf39d3a4c24acc6876dc2ffcb83",
            "zs": "2.0",
            "subtractNum": "0.0"
          },
          {
            "teamName": "战队测试名",
            "addNum": "0.0",
            "teamId": "229287cc74644db79a190b00a5f6d547",
            "zs": "0.0",
            "subtractNum": "0.0"
          }
        ]
      }
    ],
    "total": 1,
    "totalPage": 1
  }
}

7、最终显示效果:

?

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-03 16:03:16  更:2022-03-03 16:04:32 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 10:10:32-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码