javascript - 从 API 响应中获取数据并显示在表格中

标签 javascript ajax

我正在尝试创建一个表,通过使用 ajax 调用从服务器获取数据来定期显示更新。

我正在尝试从我的服务器获取数据并使用新数据更新我的 TableView 。

这是我的 Javascript 函数。

function updateSlaveTable() {

  fetch('{{route(' pusher ')}}', {
        method: 'post',
        mode: 'cors',
        headers: {
          'Content-Type': 'application/json', // sent request
          'Accept': 'application/json' // expected data sent back
        },
        body: JSON.stringify({
          "mac": "{{$slaves['mac']}}"
        })
      })
    .then((res) => res.json())
    .then(function(res) {
      //alert(JSON.stringify(res));
      //setInterval(updateSlaveTable, 1000)

      $.getJSON("res.json", function(slaves) {
        var slave_data = '';
        $.each(res.slave_id, function(key, value) {
          // if(value.type == "door_sensor")
          //{
          slave_data += '<tr>';
          slave_data += '<td>' + value.name + '</td>';
          slave_data += '<td>' + value.slave_id + '</td>';
          slave_data += '<td>' + value.type + '</td>';
          slave_data += '<td>' + value.status + '</td>';
          slave_data += '<td>' + value.value + '</td>';
          slave_data += '<td>' + value.mode + '</td>';
          slave_data += '<td>' + value.name1 + '</td>';
          slave_data += '<td>' + value.name2 + '</td>';
          slave_data += '<td>' + value.name3 + '</td>';
          slave_data += '<td>' + value.name4 + '</td>';
          slave_data += '<td>' + value.s1 + '</td>';
          slave_data += '<td>' + value.s2 + '</td>';
          slave_data += '<td>' + value.s3 + '</td>';
          slave_data += '<td>' + value.s4 + '</td>';
          slave_data += '<td>' + value.voltage + '</td>';
          slave_data += '<td>' + value.temp + '</td>';
          slave_data += '<td>' + value.hum + '</td>';
          slave_data += '</tr>';
          // }     
        });
        $('#slave_table').append(slave_data);
      });
    });

})
.catch(function(error) {
  // alert(error);
  // setInterval(updateSlaveTable, 1000); // <-- there was a network problem, 
  //     but still, program the next one!
})

}

updateSlaveTable();

我将数据正确地获取到函数中。回复如下

{
"3":
    {"value":"in value same","status":"in status same","volt":"in volt same"},
"4":
    {"value":"in value same","status":"in status same","volt":"in volt same"},
"5":
    {"status":"in status same","temp":"in temp same","hum":"in humidity same","volt":"in volt same"},
"6":
    {"status":"in status same","volt":"in volt same"},
"7":
    {"status":"in status same","s1":"in s1 same","s2":"in s2 same","s3":"in s3 same"},
"9":
    {"status":"in status same","temp":"in temp same","hum":"in humidity same","volt":"in volt same"},
"10":
    {"value":"in value same","status":"in status same","volt":"in volt same"},

"message":"no Change"
}

我对 JavaScript 的经验很少,所以请不要介意这个简单的问题

最佳答案

如果您在 res 中的数据如我在下面看到的那样,则 $.each(res.slave_id,... 无效,因为 res 没有slave_id 属性。您的键是数字,因此您可以使用 Object.keys(res).map(key => res[key]).forEach(obj => console.log 迭代它们(对象))

映射之后,您将得到一个对象数组,该值可以是表格行。

关于javascript - 从 API 响应中获取数据并显示在表格中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55160131/

相关文章:

javascript - 如何在浏览器(尤其是 Chrome)中将视频和摄像头录制合并在一起?

javascript - 有没有办法从 js 对象中删除整个属性

javascript - JQuery/PHP 表单未提交

javascript - 测试开关中的多个案例,例如 OR (||)

php - 最小化动态内容的 ajax/jquery 函数

jquery - 如何在使用ajax时自动隐藏flash消息

javascript - 当所有ajax完成时如何触发函数?

javascript - 保存带有散列标记的文本(Javascript - PHP - MySQL)

javascript - 如何更新重复列表中的特定范围文本?

javascript - 如何在本地存储中存储和检索购物车商品?