Twig 模板引擎中具有多个元素的 Foreach 循环
Foreach loop with multiple element in Twig template engine
我正在使用 Twig 作为我的 PHP 网络应用程序的模板框架。
我想知道是否有一种快速的方法可以在 foreach 块中获取多个元素。
这是我的数据:
users=>[
["name"=>"User1"],
["name"=>"User2"],
["name"=>"User3"],
["name"=>"User4"],
["name"=>"User5"],
["name"=>"User6"]
]
这将是一个标准循环(每个项目):
<ul>
{% for user in users %}
<li>{{ user.name }}</li>
{% endfor %}
</ul>
但这就是我在 n 元素块中所需要的(在此示例中 n=3)
<ul>
<li>User1</li>
<li>User2</li>
<li>User3</li>
</ul>
<ul>
<li>User4</li>
<li>User5</li>
<li>User6</li>
</ul>
在 Twig 中有一种快速的方法可以做到这一点,还是我应该以不同的方式准备数据,再增加一个子数组层?
看来您需要使用 batch
过滤器:
{% set items = ['a', 'b', 'c', 'd', 'e', 'f', 'g'] %}
<table>
{% for row in items|batch(3, 'No item') %}
<tr>
{% for column in row %}
<td>{{ column }}</td>
{% endfor %}
</tr>
{% endfor %}
</table>
它将呈现:
<table>
<tr>
<td>a</td>
<td>b</td>
<td>c</td>
</tr>
<tr>
<td>d</td>
<td>e</td>
<td>f</td>
</tr>
<tr>
<td>g</td>
<td>No item</td>
<td>No item</td>
</tr>
</table>
我正在使用 Twig 作为我的 PHP 网络应用程序的模板框架。
我想知道是否有一种快速的方法可以在 foreach 块中获取多个元素。
这是我的数据:
users=>[
["name"=>"User1"],
["name"=>"User2"],
["name"=>"User3"],
["name"=>"User4"],
["name"=>"User5"],
["name"=>"User6"]
]
这将是一个标准循环(每个项目):
<ul>
{% for user in users %}
<li>{{ user.name }}</li>
{% endfor %}
</ul>
但这就是我在 n 元素块中所需要的(在此示例中 n=3)
<ul>
<li>User1</li>
<li>User2</li>
<li>User3</li>
</ul>
<ul>
<li>User4</li>
<li>User5</li>
<li>User6</li>
</ul>
在 Twig 中有一种快速的方法可以做到这一点,还是我应该以不同的方式准备数据,再增加一个子数组层?
看来您需要使用 batch
过滤器:
{% set items = ['a', 'b', 'c', 'd', 'e', 'f', 'g'] %}
<table>
{% for row in items|batch(3, 'No item') %}
<tr>
{% for column in row %}
<td>{{ column }}</td>
{% endfor %}
</tr>
{% endfor %}
</table>
它将呈现:
<table>
<tr>
<td>a</td>
<td>b</td>
<td>c</td>
</tr>
<tr>
<td>d</td>
<td>e</td>
<td>f</td>
</tr>
<tr>
<td>g</td>
<td>No item</td>
<td>No item</td>
</tr>
</table>