zoukankan      html  css  js  c++  java
  • element框架的teble表格的数据展示由横向转向竖向

    <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) => {
                    let arr = []
                    for (let key in row) {
                        arr.push(row[key])
                    }
                    return arr
                })
                console.log(matrixData)
                // 加入标题拼接最终的数据
                this.transData = matrixData[0].map((col, i) => {
                    return [this.originTitle[i], ...matrixData.map((row) => {
                        return row[i]
                    })]
                })
                console.log(this.transData)
            }
        }
    </script>
    
    <style lang="scss" scoped>
        .m50 {
            margin: 50px;
        }
    </style>
  • 相关阅读:
    压缩与解压缩
    权限和特殊权限
    用户和组
    bash基础特性
    vim编辑器
    目录及文件操作命令
    ye
    软件包的安装与管理
    磁盘管理
    归档与展开归档
  • 原文地址:https://www.cnblogs.com/aidixie/p/13323812.html
Copyright © 2011-2022 走看看