【vue】Element UI实现表格表头纵向显示
element实现表格表头纵向显示我们正常使用Element UI写表格的时候,<el-table-column/> 标签里面都是纵向的。那么我们的需求有时候会要求行列转换,那么来看看咋整吧....(想起了当年的python作业...虽说整出来后觉得简单,但做的时候还是浪费了很多时间,好在开源yyds,找到了解决办法。)下面参考来自:http://www.manongjc.com/de
·
element实现表格表头纵向显示 我们正常使用Element UI写表格的时候,<el-table-column/> 标签里面都是纵向的。那么我们的需求有时候会要求行列转换,那么来看看咋整吧....(想起了当年的python作业...虽说整出来后觉得简单,但做的时候还是浪费了很多时间,好在开源yyds,找到了解决办法。)
下面参考来自:http://www.manongjc.com/detail/18-mjmvpumszjdxfut.html
🌰展示效果
<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>
估计到这,你们也就知道怎么弄了....
下面是结合我自身的项目的总结🎯
项目中的数据是通过接口来的,那么其实和上面的🌰页差不多,就是替换下数据。但是后端传给我的借口里面还有列的名字,因此需要做一点小改动。
接口处理如下:
getTotal() {
this.$axios
.get(`${CUSTOMER_URL}/api/statistics/question/inventory`)
.then(res => {
if (res.data.code == 0) {
this.tableData = res.data.data.questionInventoryVOList.map(item => {
return item; //这里返回所有数据
});
let arr = res.data.data.questionInventoryVOList.map(item => {
return item.questionCategory; //这里返回列的名字
});
this.transTitle = [
'',
...arr
]
this.afterGetData() //此处调用方法
} else {
this.$message.error(res.error);
}
})
.catch(error => {
if (error.res.data) {
this.$message.error(error.res.data.error);
}
});
}
//加入数据
if(matrixData.length>0){
this.transData = matrixData[0].map((col, i) => {
return [
this.originTitle[i],
...matrixData.map(row => {
return row[i+1]; //因为数据多出一行,需要从索引1开始
})
];
});
this.transData.pop() //删掉多余行
}
<el-table
border
style="margin-top: 50px;"
:header-cell-style="{ background: '#F5F5F5' }"
: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>
更多推荐
已为社区贡献6条内容
所有评论(0)