ElementUI table表格列动态渲染
一、概述
一般写table时,列都是固定。现有业务需求,列是不固定的。根据api返回的数据,进行动态渲染。
官方table示例,链接如下:
https://element.eleme.cn/#/zh-CN/component/table
二、实现
在此基础上,增加tableHeader 变量,用来动态渲染。
test.vue

<template> <div class="root"> <el-table :data="tableData" style="width: 100%" :fit='true' :default-sort="{prop: 'date', order: 'descending'}" > <el-table-column :prop="index" :label="item" sortable show-overflow-tooltip v-for="(item, index) in tableHeader" :key="index"> </el-table-column> </el-table> </div> </template> <script> export default { name: "test", data() { return { tableHeader: { date: "日期", name: "姓名", address: "地址", }, tableData: [{ date: '2016-05-02', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄', }, { date: '2016-05-04', name: '王小虎', address: '上海市普陀区金沙江路 1517 弄', }, { date: '2016-05-01', name: '王小虎', address: '上海市普陀区金沙江路 1519 弄', }, { date: '2016-05-03', name: '王小虎', address: '上海市普陀区金沙江路 1516 弄', }] } }, methods: { formatter(row, column) { return row.address; } } } </script> <style scoped> .root { margin: 20px 25px 0px 25px; } </style>
效果如下:
说明:
修改tableHeader 和tableData,注意对应关系即可。
:fit='true' 宽度自适应
sortable 排序
show-overflow-tooltip 当内容过长被隐藏时显示
再增加2列,修改修改tableHeader 和tableData

<template> <div class="root"> <el-table :data="tableData" style="width: 100%" :fit='true' :default-sort="{prop: 'date', order: 'descending'}" > <el-table-column :prop="index" :label="item" sortable show-overflow-tooltip v-for="(item, index) in tableHeader" :key="index"> </el-table-column> </el-table> </div> </template> <script> export default { name: "test", data() { return { tableHeader: { date: "日期", name: "姓名", address: "地址", age:"年龄", phone:"电话", }, tableData: [{ date: '2016-05-02', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄', age:18, phone:"12345678910", }, { date: '2016-05-04', name: '王小虎', address: '上海市普陀区金沙江路 1517 弄', age:19, phone:"12345678911", }, { date: '2016-05-01', name: '王小虎', address: '上海市普陀区金沙江路 1519 弄', age:20, phone:"12345678912", }, { date: '2016-05-03', name: '王小虎', address: '上海市普陀区金沙江路 1516 弄', age:21, phone:"12345678913", }] } }, methods: { formatter(row, column) { return row.address; } } } </script> <style scoped> .root { margin: 20px 25px 0px 25px; } </style>
效果如下:
本文参考链接:
https://www.jianshu.com/p/064a49f1752c
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
2019-04-27 基于TCPCopy的仿真压测方案
2018-04-27 python 全栈开发,Day30(第一次面向对象考试)
2018-04-27 python 全栈开发,Day30(纸牌游戏,异常和错误,异常处理)