数组数据不会显示在表中

Array data wont display in a table

本文关键字:显示 数据 数组      更新时间:2023-12-03

我有一个ajax函数,它向api发送get请求,并以以下格式返回数据-

{
    "firstname": "John",
    "lastname": "Doe",
    "email": "doej@gmail.com",
    "subjects": [
      {
        "id": 1,
        "name": "maths"
      },
      {
        "id": 2,
        "name": "chemistry"
      }
    ]
  },

我需要在表格中显示这些数据,但我很难使主题数组正确显示(在一个表格单元格中显示为列表)。我试图将数组数据放入主表中的另一个表中,但没有成功。我认为我在迭代循环中的某个地方出错了。

function getPeople() {

     $.ajax({
         type: "GET",
         url: "http://example.com",
         contentType: "application/json; charset=utf-8",
         crossDomain: true,
         dataType: "json",
         success: function (data, status, jqXHR) {

             // fill a table with the JSON
           $("table.mytable").html("<tr><th></th><th>First Name</th><th>Last Name</th><th>Subjects</th></tr>"  );
for (var i = 0; i < data.length; i++) {
        for (var j = 0; j < data[i].subjects.length; j++) {
          var subjects = data[i].subjects[j];
        $("table.insidetable").append('<tr><td>' + subjects + 'tr><td>')
      }
    $("table.mytable").append('<tr><td><input type = "checkbox" id = '+data[i].id+'>'  + "</td><td>" + data[i].firstname + "</td><td>" + data[i].lastname + "</td><td>" + "table.insidetable"  + "</td></tr>");
}
         },
         error: function (jqXHR, status) {
             // error handler
             console.log(jqXHR);
             alert('fail' + status.code);
         }
      });
   }

下面是正在运行(测试)的代码。

var data = [{
  "firstname": "John",
  "lastname": "Doe",
  "email": "doej@gmail.com",
  "subjects": [
    {
        "id": 1,
    "name": "maths"
    },
    {
        "id": 2,
        "name": "chemistry"
    }
        ]
},
{
  "firstname": "Steve",
  "lastname": "Gentile",
  "email": "steve@gmail.com",
  "subjects": [
    {
    "id": 1,
    "name": "history"
    },
    {
        "id": 2,
    "name": "geography"
    }
  ]
}];
$("table.mytable").html("<tr><th></th><th>First Name</th><th>Last Name</th><th>Subjects</th></tr>");
for (var i = 0; i < data.length; i++) {
    var subjectList = '';
    for (var j = 0; j < data[i].subjects.length; j++) {
      subjectList += '<li>' + data[i].subjects[j].name + '</li>';
    }
    $("table.mytable").append('<tr><td><input type="checkbox" id=' + i +'/></td><td>' + data[i].firstname + '</td><td>' + data[i].lastname + '</td><td><ul>' + subjectList  + '</ul></td></tr>');
}

下面的陈述似乎有很多问题,比如

  • 标签未正确关闭
  • 正在使用不存在的属性(data[i].id)
  • 单引号和双引号不匹配

$("table.mytable").append('<tr><td><input type = "checkbox" id = '+data[i].id+'>'  + "</td><td>" +data[i].firstname + "</td><td>" + data[i].lastname + "</td><td>" + "table.insidetable"+ "</td></tr>");

猜测您是否缺少'<'

行中:

 $("table.insidetable").append('<tr><td>' + subjects + 'tr><td>')

还有

$("table.mytable").append('<tr><td><input type = "checkbox" id = '+data[i].id+'>'  + "</td><td>" + data[i].firstname + "</td><td>" + data[i].lastname + "</td><td>" + "table.insidetable"  + "</td></tr>");

我认为你不应该附加"表.内部表"?这将被视为值"table.intertable",而不是表的内容。我认为这应该是类似$("table.insidetable").val() 的东西