element el-table实现多级表头的代码
作者:菜泡泡@
多级表头的作用与优势,多级表头能够清晰地展示数据的层次结构,帮助我们更好地理解数据之间的关系,下面通过本文给大家介绍element el-table实现多级表头的代码,感兴趣的朋友跟随小编一起看看吧
效果图:
<template> <div class="result-wrapper"> <dynamic-table :table-data="tableData" :table-header="tableConfig" v-if="dynamicTableShow"></dynamic-table> </div> </template> <script> import {getVehicheStockList} from "@/api/tool/dataScreen"; import DynamicTable from './DynamicTable' export default { components: { DynamicTable }, data () { return { dynamicTableShow: true, // 表数据 tableData: [ { colro3UG: '', qty3UG: '', frontColro3UE: '', frontQty3UE: '', isPunching3UE:'', afterColro3UE: '', afterQty3UE: '', frontColro3LN: '', frontQty3LN: '', isPunching4D:'', after4DColro3LN: '', after4DQty3LN: '', isPunching5D:'', after5DColro3LN: '', after5DQty3LN: '', isPunchingS:'', frontSColro2ZY: '', frontSQty2ZY: '', isPunchingN:'', frontNColro2ZY: '', frontNQty2ZY: '', afterColro2ZY: '', afterQty2ZY: '', }, { colro3UG: '', qty3UG: '', frontColro3UE: '', frontQty3UE: '', isPunching3UE:'', afterColro3UE: '', afterQty3UE: '', frontColro3LN: '', frontQty3LN: '', isPunching4D:'', after4DColro3LN: '', after4DQty3LN: '', isPunching5D:'', after5DColro3LN: '', after5DQty3LN: '', isPunchingS:'', frontSColro2ZY: '', frontSQty2ZY: '', isPunchingN:'', frontNColro2ZY: '', frontNQty2ZY: '', afterColro2ZY: '', afterQty2ZY: '', }, { colro3UG: '', qty3UG: '', frontColro3UE: '', frontQty3UE: '', isPunching3UE:'', afterColro3UE: '', afterQty3UE: '', frontColro3LN: '', frontQty3LN: '', isPunching4D:'', after4DColro3LN: '', after4DQty3LN: '', isPunching5D:'', after5DColro3LN: '', after5DQty3LN: '', isPunchingS:'', frontSColro2ZY: '', frontSQty2ZY: '', isPunchingN:'', frontNColro2ZY: '', frontNQty2ZY: '', afterColro2ZY: '', afterQty2ZY: '', }, { colro3UG: '', qty3UG: '', frontColro3UE: '', frontQty3UE: '', isPunching3UE:'', afterColro3UE: '', afterQty3UE: '', frontColro3LN: '', frontQty3LN: '', isPunching4D:'', after4DColro3LN: '', after4DQty3LN: '', isPunching5D:'', after5DColro3LN: '', after5DQty3LN: '', isPunchingS:'', frontSColro2ZY: '', frontSQty2ZY: '', isPunchingN:'', frontNColro2ZY: '', frontNQty2ZY: '', afterColro2ZY: '', afterQty2ZY: '', }, { colro3UG: '', qty3UG: '', frontColro3UE: '', frontQty3UE: '', isPunching3UE:'', afterColro3UE: '', afterQty3UE: '', frontColro3LN: '', frontQty3LN: '', isPunching4D:'', after4DColro3LN: '', after4DQty3LN: '', isPunching5D:'', after5DColro3LN: '', after5DQty3LN: '', isPunchingS:'', frontSColro2ZY: '', frontSQty2ZY: '', isPunchingN:'', frontNColro2ZY: '', frontNQty2ZY: '', afterColro2ZY: '', afterQty2ZY: '', }, { colro3UG: '', qty3UG: '', frontColro3UE: '', frontQty3UE: '', isPunching3UE:'', afterColro3UE: '', afterQty3UE: '', frontColro3LN: '', frontQty3LN: '', isPunching4D:'', after4DColro3LN: '', after4DQty3LN: '', isPunching5D:'', after5DColro3LN: '', after5DQty3LN: '', isPunchingS:'', frontSColro2ZY: '', frontSQty2ZY: '', isPunchingN:'', frontNColro2ZY: '', frontNQty2ZY: '', afterColro2ZY: '', afterQty2ZY: '', }, { colro3UG: '', qty3UG: '', frontColro3UE: '', frontQty3UE: '', isPunching3UE:'', afterColro3UE: '', afterQty3UE: '', frontColro3LN: '', frontQty3LN: '', isPunching4D:'', after4DColro3LN: '', after4DQty3LN: '', isPunching5D:'', after5DColro3LN: '', after5DQty3LN: '', isPunchingS:'', frontSColro2ZY: '', frontSQty2ZY: '', isPunchingN:'', frontNColro2ZY: '', frontNQty2ZY: '', afterColro2ZY: '', afterQty2ZY: '', }, { colro3UG: '', qty3UG: '', frontColro3UE: '', frontQty3UE: '', isPunching3UE:'', afterColro3UE: '', afterQty3UE: '', frontColro3LN: '', frontQty3LN: '', isPunching4D:'', after4DColro3LN: '', after4DQty3LN: '', isPunching5D:'', after5DColro3LN: '', after5DQty3LN: '', isPunchingS:'', frontSColro2ZY: '', frontSQty2ZY: '', isPunchingN:'', frontNColro2ZY: '', frontNQty2ZY: '', afterColro2ZY: '', afterQty2ZY: '', }, { colro3UG: '', qty3UG: '', frontColro3UE: '', frontQty3UE: '', isPunching3UE:'', afterColro3UE: '', afterQty3UE: '', frontColro3LN: '', frontQty3LN: '', isPunching4D:'', after4DColro3LN: '', after4DQty3LN: '', isPunching5D:'', after5DColro3LN: '', after5DQty3LN: '', isPunchingS:'', frontSColro2ZY: '', frontSQty2ZY: '', isPunchingN:'', frontNColro2ZY: '', frontNQty2ZY: '', afterColro2ZY: '', afterQty2ZY: '', }, ], // 表头数据 tableConfig: [ { id: 1, label: '3UG', prop: '', children: [ { id: 11, label: '颜色', prop: 'colro3UG' }, { id: 12, label: '数量', prop: 'qty3UG' } ] }, { id: 2, label: '3UE', prop: '', children: [ { id: 21, label: '前', prop: '', children: [ { id: 211, label: '颜色', prop: 'frontColro3UE' }, { id: 212, label: '数量', prop: 'frontQty3UE' } ] }, { id: 22, label: '后', prop: '', children: [ { id: 221, label: '是否冲孔', prop: 'isPunching3UE' },{ id: 222, label: '颜色', prop: 'afterColro3UE' },{ id: 223, label: '数量', prop: 'afterQty3UE' }, ] } ] }, { id: 3, label: '3LN', prop: '', children: [ { id: 31, label: '前', prop: '', children: [ { id: 311, label: '颜色', prop: 'frontColro3LN' }, { id: 312, label: '数量', prop: 'frontQty3LN' } ] }, { id: 32, label: '后', prop: '', children: [ { id: 321, label: '4D', prop: '', children: [ { id: 3211, label: '是否冲孔', prop: 'isPunching4D', }, { id: 3212, label: '颜色', prop: 'after4DColro3LN' }, { id: 3213, label: '数量', prop: 'after4DQty3LN' } ] }, { id: 322, label: '5D', prop: '', children: [ { id: 3221, label: '是否冲孔', prop: 'isPunching5D', }, { id: 3222, label: '颜色', prop: 'after5DColro3LN' }, { id: 3223, label: '数量', prop: 'after5DQty3LN' } ] } ] } ] }, { id: 4, label: '2ZY', prop: '', children: [ { id: 41, label: '前', prop: '', children: [ { id: 411, label: 'S版', prop: '', children: [ { id: 1, label: '是否冲孔', prop: 'isPunchingS', }, { id: 2, label: '颜色', prop: 'frontSColro2ZY' }, { id: 3, label: '数量', prop: 'frontSQty2ZY' } ] }, { id: 412, label: 'N版', prop: '', children: [ { id: 4121, label: '是否冲孔', prop: 'isPunchingN', }, { id: 4122, label: '颜色', prop: 'frontNColro2ZY' }, { id: 4123, label: '数量', prop: 'frontNQty2ZY' } ] } ] }, { id: 42, label: '后', prop: '', children: [ { id: 421, label: '颜色', prop: 'afterColro2ZY' }, { id: 422, label: '数量', prop: 'afterQty2ZY' } ] } ] } ] } }, created() { this.getVehicheStockList() }, methods: { async getVehicheStockList(){ await getVehicheStockList().then((res)=>{ // 3UG if(res.data['3UG']){ res.data['3UG'].forEach((item0,index0)=>{ // this.$set(this.tableData[index0],'colro3UG', item0.vehiche); this.$set(this.tableData[index0],'qty3UG', item0.qty); }) } // 3UE if(res.data['3UE']){ const location0Array = []; const location1Array = []; res.data['3UE'].forEach((obj)=>{ if (obj.location === "0") { location0Array.push(obj); location0Array.forEach((item,index)=>{ // this.$set(this.tableData[index],'frontColro3UE',item.vehiche); this.$set(this.tableData[index],'frontQty3UE', item.qty); }) } else if (obj.location === "1") { location1Array.push(obj); location1Array.forEach((item,index)=>{ this.$set(this.tableData[index],'isPunching3UE', item.isPunching=='0'?'否':'是'); // this.$set(this.tableData[index],'afterColro3UE', item.vehiche); this.$set(this.tableData[index],'afterQty3UE' , item.qty); }) } }) // res.data['3UE'].forEach((item1,index1)=>{ // // 前 // if(item1.location=='0'){ // // this.$set(this.tableData[index1],'frontColro3UE',item1.vehiche); // this.$set(this.tableData[index1],'frontQty3UE', item1.qty); // }else if(item1.location=='1'){//后 // this.$set(this.tableData[index1],'isPunching3UE', item2.isPunching=='0'?'否':'是'); // // this.$set(this.tableData[index1],'afterColro3UE', item2.vehiche); // this.$set(this.tableData[index1],'afterQty3UE' , item2.qty); // } // }) } // 3LN if(res.data['3LN']){ const location0Array = []; const location1Array = []; res.data['3LN'].forEach((obj)=>{ if (obj.location === "0") { location0Array.push(obj); location0Array.forEach((item,index)=>{ // this.$set(this.tableData[index],'frontColro3LN',item.vehiche); this.$set(this.tableData[index],'frontQty3LN', item.qty); }) } else if (obj.location === "1") { location1Array.push(obj); location1Array.forEach((item,index)=>{ if(item.vehiche=='3LNH'){ this.$set(this.tableData[index],'isPunching4D', item.isPunching=='0'?'否':'是'); // this.$set(this.tableData[index],'after4DColro3LN', item.vehiche); this.$set(this.tableData[index],'after4DQty3LN' , item.qty); }else if(item.vehiche=='3LNQ'){ this.$set(this.tableData[index],'isPunching5D', item.isPunching=='0'?'否':'是'); // this.$set(this.tableData[index],'after4DColro3LN', item.vehiche); this.$set(this.tableData[index],'after4DQty3LN', item.qty ); } }) } }) } // 3LN if(res.data['2ZY']){ const location0Array = []; const location1Array = []; res.data['2ZY'].forEach((obj)=>{ if (obj.location === "0") { location0Array.push(obj); location0Array.forEach((item,index)=>{ //S if(item.vehiche=='2ZYF'){ this.$set(this.tableData[index],'isPunchingS', item.isPunching=='0'?'否':'是'); // this.$set(this.tableData[index],'frontSColro2ZY', item.vehiche); this.$set(this.tableData[index],'frontSQty2ZY' , item.qty); }else if(item.vehiche=='2ZYQ'){//N this.$set(this.tableData[index],'isPunchingN', item.isPunching=='0'?'否':'是'); // this.$set(this.tableData[index],'frontNColro2ZY', item.vehiche); this.$set(this.tableData[index],'frontNQty2ZY', item.qty ); } }) } else if (obj.location === "1") { location1Array.push(obj); location1Array.forEach((item,index)=>{ // this.$set(this.tableData[index],'afterColro2ZY',item.vehiche); this.$set(this.tableData[index],'afterQty2ZY', item.qty); }) } }) // res.data['2ZY'].forEach((item3,index3)=>{ // // 前 // if(item3.location=='0'){ // //S // if(item3.vehiche=='2ZYF'){ // this.$set(this.tableData[index3],'isPunchingS', item3.isPunching=='0'?'否':'是'); // // this.$set(this.tableData[index3],'frontSColro2ZY', item3.vehiche); // this.$set(this.tableData[index3],'frontSQty2ZY' , item3.qty); // }else if(item3.vehiche=='2ZYQ'){//N // this.$set(this.tableData[index3],'isPunchingN', item3.isPunching=='0'?'否':'是'); // // this.$set(this.tableData[index3],'frontNColro2ZY', item3.vehiche); // this.$set(this.tableData[index3],'frontNQty2ZY', item3.qty ); // } // }else if(item3.location=='1'){ //后 // // this.$set(this.tableData[index3],'afterColro2ZY',item3.vehiche); // this.$set(this.tableData[index3],'afterQty2ZY', item3.qty); // } // }) } }) }, } } </script> <style scoped lang="scss"> .policy-wrapper{ margin-top: 10px; } .result-wrapper{ margin: 20px auto 0; } ::v-deep .el-table .el-table__header-wrapper .el-table__header tr th, .el-table .el-table__fixed-right .el-table__header tr th { background: transparent !important; color: #fff !important; font-size: 18px; font-weight: 600; } ::v-deep .el-table .el-table__cell.is-center { text-align: center; color: #fff; } </style>
<template> <el-table-column :label="coloumnHeader.label" :prop="coloumnHeader.label" align="center"> <template v-for="item in coloumnHeader.children"> <tableColumn v-if="item.children && item.children.length" :key="item.id" :coloumn-header="item"></tableColumn> <el-table-column v-else :key="item.name" :label="item.label" :prop="item.prop" align="center"></el-table-column> </template> </el-table-column> </template> <script> export default { name: 'tableColumn', props: { coloumnHeader: { type: Object, required: true } } } </script> <style scoped> </style>
<template> <el-table :data="tableData" border :height="height"> <template v-for="item in tableHeader"> <table-column v-if="item.children && item.children.length" :key="item.id" :coloumn-header="item"></table-column> <el-table-column v-else :key="item.id" :label="item.label" :prop="item.prop" align="center"></el-table-column> </template> </el-table> </template> <script> import TableColumn from './TableColumn.vue' export default { props: { // 表格的数据 tableData: { type: Array, required: true }, // 多级表头的数据 tableHeader: { type: Array, required: true }, // 表格的高度 height: { type: String, default: '900' } }, components: { TableColumn } } </script> <style scoped> </style>
到此这篇关于element el-table写多级表头的文章就介绍到这了,更多相关element el-table多级表头内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!