无表头,不固定列,不固定行,动态渲染

<template>
    <div class="m50" id="tablestitle">
    
      <!-- <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"  :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分/题',
              branch:"12"
            },
            {
            //   type: '填空题',
              num: '5题',
              average: '3分/题',
              branch:"18"
            },
            {
            //   type: '选择题',
              num: '2题',
              average: '10分/题',
              branch:"54"
            },
            {
            //   type: '选择题',
              num: '',
              average: '10分/题',
              branch:"12"
            },
            {
            //   type: '选择题',
              num: '',
              average: '10分/题',
              branch:"11"
            },
            {
            //   type: '选择题',
              num: '44',
              average: '',
              branch:"12"
            },
            {
            //   type: '选择题',
              num: '55',
              average: '',
            }
          ],
          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>
    .m50 {
        margin: 50px;
    }
    #tablestitle .el-table__header .is-leaf{
        height:0px !important;
        display: none;
    }
    #tablestitle .gutter{
        display: none;
    }
    </style>

  效果

猜你喜欢

转载自www.cnblogs.com/Jerry1208/p/12197556.html
今日推荐