Vue 纵向Table转横向Table (转置)

效果

数组参照矩阵思想, 对数组进行转置。

缺点: 转置后的数组仅是单纯的存每一行数据的数组用于展示, 失去了原数组的数组结构. 建议该方法用于仅展示的需求.

<template>
<div class="m50">

  <el-table border style="margin-top: 50px;" :data="originData">
    <el-table-column label="题型" property="type" align="center">
    </el-table-column>
    <el-table-column label="数量" property="num" align="center">
    </el-table-column>
    <el-table-column label="均分" property="average" align="center">
    </el-table-column>
  </el-table>

  <!-- 转化后 -->
  <el-table border style="margin-top: 50px;" :data="transData">
    <el-table-column v-for="(item, index) in transTitle" :label="item" :key="index" align="center">
      <template slot-scope="scope">
        {{scope.row[index]}}
      </template>
    </el-table-column>
  </el-table>

</div>
</template>

<script>
export default {
  data() {
    return {
      // originData 为后端原始正常的数据, 此数据按正常表格展示 一行一行的数据
      // 保证数组里每一个对象中的字段顺序, 从上到下 一次对应显示表格中的从左到右
      originData: [{
          type: '选择题',
          num: '5题',
          average: '3分/题',
        },
        {
          type: '填空题',
          num: '5题',
          average: '3分/题',
        },
        {
          type: '选择题',
          num: '2题',
          average: '10分/题',
        }
      ],
      originTitle: ['题型', '数量', '均分'], // originTitle 该标题为 正常显示的标题, 数组中的顺序就是上面数据源对象中的字段标题对应的顺序
      transTitle: ['', '学生1', '学生2', '学生3'], // transTitle 该标题为转化后的标题, 注意多一列,  因为原来的标题变成了竖着显示了, 所以多一列标题, 第一个为空即可
      transData: [],
    }
  },
  created() {
    // 数组按矩阵思路, 变成转置矩阵
    let matrixData = this.originData.map((row, i) => {
      let arr = []
      for (let key in row) {
        arr.push(row[key])
      }
      return arr
    })
    // 加入标题拼接最终的数据
    this.transData = matrixData[0].map((col, i) => {
      return [this.originTitle[i], ...matrixData.map((row) => {
        return row[i]
      })]
    })
  }
}
</script>

<style lang="scss" scoped>
.m50 {
    margin: 50px;
}
</style>

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,163评论 1 32
  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,275评论 0 4
  • 文 / 映寒 到了一定的年纪,我们会发现身边开始充斥着各种的声音,尤其是姑娘。朋友陆陆续续都名花有主。他们时不时的...
    一个人说阅读 507评论 0 1
  • 人们常说:“有志者事竟成。”可是,有的时候,无论我们如何努力,都无法达成心愿,甚至又回到了起点。那么,一切努力都白...
    AIHeHe阅读 450评论 0 0
  • Sketch相比PS要简单很多,使用上跟Axure一样易用。Sketch具有非常丰厚的产品线框图、布局图、设计图素...
    Cloudya云阅读 2,959评论 1 25