你如何用树枝制作一个两列的表格?

2022-08-30 20:37:48

我无法弄清楚如何在Twig循环中添加每隔一次迭代。</tr><tr>

例如:

$numArray = array(12,13,14,15,16,17,18);

传递给树枝,我会循环一个表格,如:

<table>
  {% for num in numArray %}
    <tr>
      <td>
        {{num}}
      </td>
    </tr>
  {% endfor %}
</table>

这将输出:

+-----------+
|    12     |
+-----------+
|    13     |
+-----------+
|    14     |
+-----------+
|    15     |
+-----------+
|    16     |
+-----------+
|    17     |
+-----------+
|    18     |
+-----------+

我想做的是得到这样的东西:

+-----------+-----------+
|    12     |    13     |
+-----------+-----------+
|    14     |    15     |
+-----------+-----------+
|    16     |    17     |
+-----------+-----------+
|    18     |           |
+-----------+-----------+

但是我一辈子都想不出一种方法,用任何看起来不方便的东西来替换我的行输入。老实说,我甚至不能让黑客工作。有没有办法做到这一点?或者,我应该考虑编写自己的扩展吗?


答案 1

执行此操作的正确方法是使用批处理筛选器。它是 1.12.3 中的新增功能。

<table>
{% for row in numArray|batch(2) %}
  <tr>
  {% for column in row %}
    <td>{{ column }}</td>
  {% endfor %}
  </tr>
{% endfor %}
</table>

编号: http://twig.sensiolabs.org/doc/filters/batch.html


答案 2

像这样的东西会起作用:

<table>
  <tr>
  {% for num in numArray %}
      <td>
        {{num}}
      </td>
  {% if loop.index is even %}
    </tr>
    <tr>
  {% endif %}
  {% endfor %}

  {% if num|length is odd %}
    <td></td>
  {% endif %} 
  </tr>
</table>

另一种方式,感觉不那么笨拙:

<table>
  {% for i in range(0, numArray|length-1, 2) %}
  <tr>
    <td>{{ numArray[i] }}</td>
    <td>{{ numArray[i+1]|default("") }}</td>
  </tr>
  {% endfor %}
</table>

推荐