最近要做一个需求是要写好多好多个相同逻辑但字段不同的报表,以下是代码
html
<el-table :data="ListAll">
<el-table-column v-for="(column,index) in tableColumns" :key="index" :prop="column.prop" :label="column.label" header-align="center" align="center">
</el-table-column>
</el-table>
javascript
<script>
export default{
data(){
//字段定义
tableColumns:[],
ListAll:[],
title:[]
},
methods:{
getData(){
const columnHeader = {}
//如果有固定字段可以在这里先赋值
columnHeader['字段名'] = {prop:`字段名`,label:`字段描述`}
this.$api.queryList(this.params).then((res)=>{
//这里的取值根据自己的返回结果来
this.ListAll = res.data.list //数据
//这里是把字段名,单独拆开了,title只传的列名,
//后端数据格式为HashMap,例{key:value,字段1:描述1,字段2:描述2,字段3:描述3....}
this.title=res.title
for(let key in this.title){
let value=this.title[key]
columnHeader[key]={prop:`${key}`,label:`${value}`}
}
this.tableColumns = columnHeader
//完成,list不用做处理了,在el-table赋值就可以了
})
}
}
}
</script>
完成啦!!!这样相同的逻辑就不用写多张表
另外后端处理方式各不相同,这里不好放代码,有需要私下也欢迎交流
我这里后端字段和描述的处理是存在一张对应表中,抽取到缓存中使用