后端接口返回数组嵌套数组,前台使用el-table循环表头展示

最近写项目接口全是展示实时数据、历史数据比较多
后端给我返回的接口是数组嵌套数组,如下图

在这里插入图片描述
还有一个因子表头接口返回的数组如下图
在这里插入图片描述
代码如下
首先处理因子表头

getYinzi() {
      this.$axios.get(`SysBase/GetWzFactors`).then((res) => {
        const { result } = res.data;
        this.tableHd = [];
        result.forEach((element) => {
          this.tableHd.push({
            prop: element.onfId + "Rtd",
            label: element.onfReName
              ?  `${element.onfReName} (${element.onfUnit?element.onfUnit:''})` 
              : `${element.onfName} (${element.onfUnit?element.onfUnit:''})` ,
          });
        });
        console.log(this.tableHd, "this.tableHd");
      });
    },

this.tableHd打印出来是
在这里插入图片描述
在处理后端接口数据

getTableData() {
    this.$axios.get(`SailMonitor/GetWzRealDatas`).then((res) => {
       const { result } = res.data;
       let newData = result.map((item) => {
         let result = {
           sName: item.sName,
           sGuid: item.sGuid,
           rDatetime: item.rDatetime ? item.rDatetime.replace("T", " ") : "",
         };
         item.realDatas.forEach((dataItem) => {
           if (dataItem.RDataValue) {
             result[dataItem.OnfId + dataItem.RDataType] = dataItem.RDataValue;
           }
         });
         return result;
       });
       console.log(newData,'newData')
       this.tableData = newData;
     });
   },

newData打印出来是
在这里插入图片描述
最后把
newData赋值给tableData,
在html中循环的是

<el-table-column
 v-for="(detail, index) in tableHd"
     :key="index"
     :label="detail.label"
     :prop="detail.prop"
     align="center"
   >
</el-table-column>

在这里插入图片描述
这样就可以了~
效果展示

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值