vue动态列(表头)

最近要做一个需求是要写好多好多个相同逻辑但字段不同的报表,以下是代码

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>

完成啦!!!这样相同的逻辑就不用写多张表

另外后端处理方式各不相同,这里不好放代码,有需要私下也欢迎交流

我这里后端字段和描述的处理是存在一张对应表中,抽取到缓存中使用

相关推荐
To_OC8 小时前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC8 小时前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
天渺工作室8 小时前
实现一个adblock/adblock plus等浏览器广告拦截器检测插件
前端·javascript
阳光是sunny9 小时前
Vue 项目怎么做用户行为全链路监控?轻量插件方案详解
前端·面试·架构
ZhengEnCi9 小时前
Q04-Vite禁用CSS代码分割-解决生产环境样式加载顺序混乱问题
前端·vue.js·vite
九酒9 小时前
AI Agent 开发踩坑记:口播功能非得用 APP 原生实现吗?
前端·人工智能·agent
Jackson__10 小时前
做了一段时间的AI coding后,我终于搞清了 CLI 和 MCP 的区别
前端·agent·ai编程
IT_陈寒13 小时前
JavaScript项目实战经验分享
前端·人工智能·后端
用户479492835691513 小时前
6w star,GitHub 趋势第一的 Ponytail,这个agent插件到底在火什么
前端·后端
薛定喵的谔15 小时前
我开源了一个精致的 Next.js 博客模板:Skyplume
前端·前端框架·next.js