el-table 如何把接口返回来的数据动态添加表头和内容

<template>
  <el-table :data="tableData" style="width: 100%">
    <el-table-column
      v-for="(header, index) in tableHeaders"
      :key="index"
      :prop="header.prop"
      :label="header.label">
    </el-table-column>
  </el-table>
</template>
 
<script>
export default {
  data() {
    return {
      tableHeaders: [],
      tableData: []
    };
  },
  mounted() {
    // 假设fetchData是获取接口数据的函数
    this.fetchData();
  },
  methods: {
    fetchData() {
      // 模拟接口数据获取
      axios.get('/api/data').then(response => {
        // 假设返回的数据格式为 { headers: [], data: [] }
        const { headers, data } = response.data;
        
        // 设置表头
        this.tableHeaders = headers.map(header => ({
          label: header,
          prop: header.toLowerCase() // 假设表头对应的属性名为表头名称的小写
        }));
        
        // 设置表格数据
        this.tableData = data;
      });
    }
  }
};
</script>

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现el-table多级表头动态改变表头数据,首先需要准备两组数据。一组数据用于实现表头的结构,另一组数据用于内容渲染。在el-table中,可以使用el-table-column标签嵌套的方式来实现多级表头。 在表头数据中,每个el-table-column代表一个表头列。可以使用label属性定义列名,prop属性定义对应的数据字段。如果有多级表头,可以通过嵌套el-table-column来实现。每个el-table-column可以设置子列,通过v-for循环遍历表头数据动态生成多级表头的结构。 在内容渲染时,可以使用prop属性来指定对应的数据字段进行渲染。根据你提供的示例,可以使用v-for循环遍历表头数据中的子列来渲染内容。 通过以上的设置,当表头数据发生改变时,el-table动态生成对应的多级表头结构,并且根据内容渲染的数据进行渲染。你可以根据具体需求动态改变表头数据,并且保证内容渲染的数据结构与表头数据对应即可实现el-table多级表头动态改变表头数据的效果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [el-table 多级表头动态生成;一级表头,根据数据动态生成,二级固定。](https://blog.csdn.net/weixin_46753476/article/details/131282706)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [el-table多级表头,合并表头,设置样式](https://blog.csdn.net/weixin_52618969/article/details/130881560)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值