1

可能重复:
在 jQuery 中动态创建表

我有两个数组,letters = [A,B,C,...]numbers = [1,2,3,...],并想生成一个 html 表,其中numbers作为标题和letters作为第一个条目(然后我可以用我拥有的值填充它)。这对于通用数组是否可行?

也就是如下图:

<table>
   <thead>
     <tr>
       <th></th>
       <th>1</th>
       <th>2</th>
       <th>3</th>
     </tr>
   </thead>
   <tbody>
     <tr id="A">
       <td>A</td>
       <td></td>
       <td></td>
       <td></td>
     </tr>
     <tr id="B">
       <td>B</td>
       <td></td>
       <td></td>
       <td></td>
     </tr>
     <tr id="C">
       <td>C</td>
       <td></td>
       <td></td>
       <td></td>
     </tr>
   </tbody>
 </table>​
4

2 回答 2

1

好的,这是我想到的第一种方法:

var letters = ["A","B","C"],
    numbers = [1,2,3],
    $table = $("<table/>"),
    $body = $("<tbody/>").appendTo($table),
    $row = $("<tr><th></th></tr>");

$.each(numbers,function(i,val){
  $("<th/>").text(val).appendTo($row);
});
$("<thead/>").append($row).appendTo($table);

$.each(letters, function(i,val) {
  $row = $("<tr/>").attr("id",val).appendTo($body);
  $("<td/>").text(val).appendTo($row);
  for (var j = 0; j < numbers.length; j++)
    $row.append("<td/");
});

$table.appendTo("body");

演示:http: //jsbin.com/ocomit/edit#javascript,html,live

是的,它可能更漂亮和/或更高效。这仅使用非常基本的 jQuery 方法 - 如果您不确定其中的任何一个,您知道在哪里看......

于 2012-07-16T11:01:43.777 回答
1

请试试这个 :

    var html = '';
    letters = [A,B,C];
    numbers = [1,2,3];
    html+= "<table><thead><tr><th></th>";
    for(i=0;i<letters.length;i++)
       html+="<th>"++letters[i]"</th>"; 
    html+= "</tr></thead>";
    html+= "<tbody>";
    for(j=0;j<numbers.length;j++)
    {
       html+="<tr id='"+numbers[j]+"'>";
       html+="<td>"+numbers[j]+"</td>";
       for(k=1;k<letters.length;k++)
           html+= "<td></td>";
       html+= "</tr>";
    }    
    html+= "</tbody>";
    html+= "</table>";

请提醒“html”,您将获得所需的输出。

于 2012-07-16T11:08:38.883 回答