使用Jade / Express.js渲染表,每行有多个元素

时间:2012-06-24 18:28:37

标签: html node.js express html-table pug

我正在尝试使用简单的对象数组中的jade渲染表。但是,不是简单地为每个对象渲染一行,而是想在每一行上渲染三个对象。

<table>
  <thead>...</thead>
  <tbody>
    <tr>
      <td>obj0</td>
      <td>obj1</td>
      <td>obj2</td>
    </tr>
    <tr>
      <td>obj3</td>
      <td>obj4</td>
      <td>obj5</td>
    </tr>
    ...
  </tbody>
</table

2 个答案:

答案 0 :(得分:6)

接受的答案在技术上有效,但我不喜欢你必须构建数据以便逻辑工作。我认为逻辑应该适应数据。因此,我想出了这个:

objects = [obj0, obj1, obj2, obj3, obj4, obj5]

table
  thead
  tbody
    - var columns = 3
    - for (var i = 0; i < objects.length; i=i+columns)
      tr
        - for (var j = 0; j < columns && i+j < objects.length; j++)
          td=objects[i+j]

答案 1 :(得分:5)

objects = [[obj0, obj1, obj2], [obj3, obj4, obj5]]

table
  thead
  tbody
  for object in objects
    tr
      for subobject in object
        td= subobject