如何在for循环中创建表行

时间:2017-03-14 10:41:33

标签: javascript tablerow

我在Javascript中对 For loop 有一点问题。这是我的代码:

$(document).ready(function() {
  $.getJSON("CAN_gen_1.json", function(json) {
    var tr;
    for (var i = 0; i < json.messages.length; i++) {
      tr = $('<tr/>');
      var details = json.messages[i];
      for (var j = 0; j <= details.signals.length; j++) {
        tr.append("<td>" + details.signals[j].start_bit + "</td>");
        tr.append("<td>" + details.signals[j].comment + "</td>");
        tr.append("<td>" + details.signals[j].bit_length + "</td>");
        tr.append("<td>" + details.signals[j].factor + "</td>");
        tr.append("<td>" + details.signals[j].offset + "</td>");
        tr.append("<td>" + details.signals[j].is_big_endian + "</td>");
        tr.append("<td>" + details.signals[j].is_signed + "</td>");
        tr.append("<td>" + details.signals[j].name + "</td>");
        $('#table_1').append(tr);
      }
    }
  });
});

我声明了一个表行(tr)。每次循环浏览json文件时都会使用它。问题是我得到一行包含所有数据。

我想剪切行以便有一个可读的表格。

查看快照:Single Data Row

4 个答案:

答案 0 :(得分:3)

这种情况正在发生,因为您每个表只创建一个<tr>

在内部循环中创建tr

$(document).ready(function() {
  $.getJSON("CAN_gen_1.json", function(json) {
    var tr;
    for (var i = 0; i < json.messages.length; i++) {
      var details = json.messages[i];
      for (var j = 0; j <= details.signals.length; j++) {
        tr = $('<tr/>');
        tr.append("<td>" + details.signals[j].start_bit + "</td>");
        tr.append("<td>" + details.signals[j].comment + "</td>");
        tr.append("<td>" + details.signals[j].bit_length + "</td>");
        tr.append("<td>" + details.signals[j].factor + "</td>");
        tr.append("<td>" + details.signals[j].offset + "</td>");
        tr.append("<td>" + details.signals[j].is_big_endian + "</td>");
        tr.append("<td>" + details.signals[j].is_signed + "</td>");
        tr.append("<td>" + details.signals[j].name + "</td>");
        $('#table_1').append(tr);
      }
    }
  });
});

这段代码有点笨拙。我建议将一个函数分解出来来创建行。这样一来,当需要创建它们并且不必重复details.signals[j]时,它就很清楚了:

function tableRowForSignal(signal) {
  return $('<tr />')
   .append($("<td>").text(signal.start_bit));
   .append($("<td>").text(signal.comment));
   .append($("<td>").text(signal.bit_length));
   .append($("<td>").text(signal.factor));
   .append($("<td>").text(signal.offset));
   .append($("<td>").text(signal.is_big_endian));
   .append($("<td>").text(signal.is_signed));
   .append($("<td>").text(signal.name));
}

$(document).ready(function() {
  $.getJSON("CAN_gen_1.json", function(json) {
    var tr;
    for (var i = 0; i < json.messages.length; i++) {
      var details = json.messages[i];
      for (var j = 0; j <= details.signals.length; j++) {
        $('#table_1').append(tableRowForSignal(details.signals[j]));
      }
    }
  });
});

答案 1 :(得分:2)

您需要为每一行

创建一个新行
  tr = $('<tr/>');
  var details = json.messages[i];
  for (var j = 0; j <= details.signals.length; j++) {
    tr.append("<td>" + details.signals[j].start_bit + "</td>");

这些行中的第一行需要在内部循环中创建进入其中的单元格。

答案 2 :(得分:1)

    $(document).ready(function() {
  $.getJSON("CAN_gen_1.json", function(json) {
    for (var i = 0; i < json.messages.length; i++) {
      var details = json.messages[i];
      for (var j = 0; j <= details.signals.length; j++) {
        var tr = $('<tr>');
        tr.append("<td>" + details.signals[j].start_bit + "</td>");
        tr.append("<td>" + details.signals[j].comment + "</td>");
        tr.append("<td>" + details.signals[j].bit_length + "</td>");
        tr.append("<td>" + details.signals[j].factor + "</td>");
        tr.append("<td>" + details.signals[j].offset + "</td>");
        tr.append("<td>" + details.signals[j].is_big_endian + "</td>");
        tr.append("<td>" + details.signals[j].is_signed + "</td>");
        tr.append("<td>" + details.signals[j].name + "</td>");
        tr.append("</tr>");
        $('#table_1').append(tr);
      }
    }
  });
});

答案 3 :(得分:-4)

您必须在for之前打开行

<tr>

在所有追加后,您应该用

关闭它
</tr>