当前位置: 首页 > article >正文

el-table表头前几列固定,后面几列根据接口返回的值不同展示不同

在使用 Element UIel-table 组件时,如果想要实现表头的前几列固定,而后面的列根据接口返回的数据动态展示,可以通过以下步骤来实现:

1. 固定表头前几列

el-table-column 中使用 fixed 属性来固定表头的前几列。例如,如果你想要固定前两列,可以这样做:

<el-table :data="tableData" style="width: 100%">
  <el-table-column prop="date" label="日期" width="150" fixed></el-table-column>
  <el-table-column prop="name" label="姓名" width="200" fixed></el-table-column>
  <!-- 动态列将从这里开始 -->
</el-table>

2. 动态生成表头

为了根据后端返回的数据动态生成表头,你需要在获取到数据之后处理这些数据,然后动态地渲染 el-table-column

假设你的后端返回的数据结构如下:

{
  "columns": [
    { "prop": "address", "label": "地址" },
    { "prop": "phone", "label": "电话" },
    // 更多列...
  ],
  "rows": [
    { "date": "2016-05-02", "name": "王小虎", "address": "上海市普陀区金沙江路 1518 弄", "phone": "12345678901" },
    // 更多行...
  ]
}

你可以这样处理并渲染:

export default {
  data() {
    return {
      tableData: [],
      dynamicColumns: []
    };
  },
  methods: {
    async fetchData() {
      const response = await this.$axios.get('/api/data'); // 假设这是你的API请求
      this.dynamicColumns = response.data.columns;
      this.tableData = response.data.rows;
    }
  },
  mounted() {
    this.fetchData();
  }
};

3. 使用 v-for 渲染动态列

在模板中使用 v-for 指令来遍历 dynamicColumns 数组,从而动态生成 el-table-column

<el-table :data="tableData" style="width: 100%">
  <el-table-column prop="date" label="日期" width="150" fixed></el-table-column>
  <el-table-column prop="name" label="姓名" width="200" fixed></el-table-column>
  <el-table-column
    v-for="column in dynamicColumns"
    :key="column.prop"
    :prop="column.prop"
    :label="column.label"
    :width="200"
  ></el-table-column>
</el-table>

4. 注意事项

  • 确保 dynamicColumns 中的每个对象都有 proplabel 属性,这对应于 el-table-columnproplabel 属性。
  • 如果需要对动态生成的列进行排序或其他操作,可以在 fetchData 方法中进一步处理 dynamicColumns
  • 动态列的宽度可以根据实际需求调整,上面的例子中设置为固定的200像素宽。

通过上述步骤,你就可以实现一个具有固定前几列且能够根据后端数据动态显示剩余列的表格了。


http://www.kler.cn/a/406425.html

相关文章:

  • 内外网交换过程中可能遇到的安全风险有哪些?
  • 人工智能|计算机视觉——微表情识别(Micro expression recognition)的研究现状
  • 【软件入门】Git快速入门
  • RocketMQ: 集群部署注意事项
  • Linux INPUT 子系统详解
  • Java LinkedList 详解
  • 从复合字符串中分割并解析多个JSON字符串
  • VR虚拟现实技术的应用领域有哪些?
  • 长文解读:OSAID 1.0,全球首个开源AI标准,审视探讨其对AI行业实践开源的影响
  • React 表单Form 中的 useWatch
  • 《Vue零基础教程》(3)创建第一个应用案例
  • java使用itext生成pdf
  • shell--第一次作业
  • 微信小程序组件详解:text 和 rich-text 组件的基本用法
  • 定长滑动窗口基础模板题:LeetCode——2379.得到K个黑块的最少涂色次数和643.子数组最大平均数 1
  • 数据结构-树状数组专题(2)
  • 商业物联网:拥抱生产力的未来
  • 2024年9月中国电子学会青少年软件编程(Python)等级考试试卷(六级)答案 + 解析
  • 基于Java Springboot旅游民宿信息管理系统
  • Linux 进程概念与进程状态
  • Elasticsearch实战应用:构建高效搜索与分析平台
  • nodejs基于微信小程序的云校园的设计与实现
  • AFSim脚本学习
  • 未来已来:少儿编程竞赛聚焦物联网,激发创新潜力
  • vue3-基于element-plus实现定制化动态表单及校验
  • CentOS使用中遇到的问题及解决方法