从复杂的JSON生成HTML表

时间:2015-11-17 14:44:10

标签: javascript json html-table

我希望将一些JSON数据生成到一个漂亮的HTML表格中,以查看有关某人在测试中的表现的统计数据。在我的JSON数据中,我按名称对每个学生进行了分组,并将他们的分数放在JSON数组中。

使用更简单的JSON,如{ "Name" : "Alfreds Futterkiste", "City" : "Berlin", "Country" : "Germany" },因为我可以为每个JSON对象生成<td>,因此会更容易。

所以要明确:我需要一种方法将对象放在嵌套数组中<tr>

我的PHP生成的JSON如下所示:

[  
   {  
      "school":"St. Paul"
   },
   {  
      "class":"4a"
   },
   {  
      "student":"Andreas",
      "taskid":[  
         2,
         1
      ],
      "level":[  
         3,
         4
      ],
      "hint":[  
         1,
         0
      ],
      "correctanswer":[  
         1,
         1
      ],
      "timeused":[  
         30,
         20
      ]
   }
]

有没有简单的方法来制作这样的桌子?我对任何设置相对简单的库都是开放的。

学生x

____________________________________________
|#taskid|level|hint|correctanswer|time used|
|‾‾‾‾‾‾‾|‾‾‾‾‾|‾‾‾‾|‾‾‾‾‾‾‾‾‾‾‾‾‾|‾‾‾‾‾‾‾‾‾|
|‾‾‾‾‾‾‾|‾‾‾‾‾|‾‾‾‾|‾‾‾‾‾‾‾‾‾‾‾‾‾|‾‾‾‾‾‾‾‾‾|
‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾‾

1 个答案:

答案 0 :(得分:0)

我有一个答案,下面是测试运行,花了我4个小时,只使用JavsScript没有像jquery等第三方库。 你可以进一步即兴发挥它。 享受。

  var jsonData = [{
    "school": "St. Paul"
  }, {
    "class": "4a"
  }, {
    "student": "Natalie",
    "taskid": [
      3,
      4
    ],
    "level": [
      1,
      2
    ],
    "hint": [
      1,
      6
    ],
    "correctanswer": [
      1,
      4
    ],
    "timeused": [
      30,
      10
    ]
  }, {
    "school": "St. Paul"
  }, {
    "class": "4a"
  }, {
    "student": "Andreas",
    "taskid": [
      2,
      1
    ],
    "level": [
      3,
      4
    ],
    "hint": [
      1,
      0
    ],
    "correctanswer": [
      1,
      1
    ],
    "timeused": [
      30,
      20
    ]
  }]

  for (var i = 0; i < jsonData.length; i++) {
    var nodeTable = document.createElement("table");
    var nodeTbody = document.createElement("tbody");

    for (var x = 0; x < Object.keys(jsonData[i]).length; x++) {
      var headerText = document.createTextNode(Object.keys(jsonData[i])[x]);
      var nodeTH = document.createElement("th");
      nodeTH.appendChild(headerText);
      document.getElementById("schoolRecord").appendChild(nodeTable).appendChild(nodeTbody).appendChild(nodeTH);
    }
    var maxLength = [];
    for (var x = 0; x < Object.keys(jsonData[i]).length; x++) {

      for (var z = 0; z < jsonData[i][Object.keys(jsonData[i])[x]].length; z++) {
        if (typeof(jsonData[i][Object.keys(jsonData[i])[x]]) !== 'string') {
          maxLength.push(jsonData[i][Object.keys(jsonData[i])[x]].length);
        }
      }
    }
    if (maxLength.length > 0) {
      maxLength = Math.max.apply(Math, maxLength);
    }
    if (maxLength.length === undefined) {
      for (var z = 0; z < maxLength; z++) {
        var nodeTR = document.createElement("tr");
        nodeTbody.appendChild(nodeTR);
        createTD(z);
      }
    } else {
      var nodeTR = document.createElement("tr");
      nodeTbody.appendChild(nodeTR);
      createTD();
    }

    function createTD(nodeValue) {
      for (var x = 0; x < Object.keys(jsonData[i]).length; x++) {
        if (typeof(jsonData[i][Object.keys(jsonData[i])[x]]) === 'string') {
          var tdText = document.createTextNode(jsonData[i][Object.keys(jsonData[i])[x]]);
          var nodeTD = document.createElement("td");
          nodeTD.appendChild(tdText);
          nodeTR.appendChild(nodeTD);
        } else {
          var tdText = document.createTextNode(jsonData[i][Object.keys(jsonData[i])[x]][nodeValue]);
          var nodeTD = document.createElement("td");
          nodeTD.appendChild(tdText);
          nodeTR.appendChild(nodeTD);
        }
      }
    }

  }
table th,

table td {

  border: 1px solid black;

  border-collapse: collapse;

}
<div id="schoolRecord">

</div>