mirror of
https://github.com/fenom-template/fenom.git
synced 2023-08-10 21:13:07 +03:00
87 lines
2.9 KiB
Markdown
87 lines
2.9 KiB
Markdown
Тег {foreach}
|
||
=============
|
||
|
||
Тег `foreach` предоставляет простой способ перебора массивов.
|
||
|
||
```smarty
|
||
{foreach $list as [$key =>] $value [index=$index] [first=$first] [last=$last]}
|
||
{* ...code... *}
|
||
{break}
|
||
{* ...code... *}
|
||
{continue}
|
||
{* ...code... *}
|
||
{foreachelse}
|
||
{* ...code... *}
|
||
{/foreach}
|
||
```
|
||
|
||
### {foreach}
|
||
|
||
Перебор значений массива $list
|
||
|
||
```smarty
|
||
{foreach $list as $value}
|
||
<div>{$value}</div>
|
||
{/foreach}
|
||
```
|
||
|
||
Перебор ключей и значений массива $list
|
||
|
||
```smarty
|
||
{foreach $list as $key => $value}
|
||
<div>{$key}: {$value}</div>
|
||
{/foreach}
|
||
```
|
||
|
||
Получение номера (индекса) итерации
|
||
|
||
```smarty
|
||
{foreach $list as $value index=$index}
|
||
<div>№{$index}: {$value}</div>
|
||
{/foreach}
|
||
```
|
||
|
||
Определение первого элемента
|
||
|
||
```smarty
|
||
{foreach $list as $value first=$first}
|
||
<div>{if $first} first item {/if} {$value}</div>
|
||
{/foreach}
|
||
```
|
||
|
||
Переменная `$first` будет иметь значение **TRUE**, если текущая итерация является первой.
|
||
Определение последнего элемента
|
||
|
||
```smarty
|
||
{foreach $list as $value last=$last}
|
||
<div>{if $last} last item {/if} {$value}</div>
|
||
{/foreach}
|
||
```
|
||
|
||
Переменная `$last` будет иметь значение **TRUE**, если текущая итерация является последней.
|
||
|
||
### {break}
|
||
|
||
Тег `{break}` используется для выхода из цикла до достижения последней итерации. Если в цикле встречается тег `{break}`, цикл завершает свою работу, и далее, выполняется код, следующий сразу за блоком цикла
|
||
|
||
### {continue}
|
||
|
||
Тег `{continue}` используется для прерывания текущей итерации. Если в цикле встречается тег `{continue}`, часть цикла, следующая после тега, не выполняется, и начинается следующая итерация. Если текущая итерация была последней, цикл завершается.
|
||
|
||
### {foreachelse}
|
||
|
||
Тег {foreachelse} ограничивает код, который должен быть выполнен, если итерируемый объект пуст.
|
||
|
||
```smarty
|
||
{var $list = []}
|
||
{foreach $list as $value}
|
||
<div>{if $last} last item {/if} {$value}</div>
|
||
{foreachelse}
|
||
<div>empty</div>
|
||
{/foreach}
|
||
```
|
||
|
||
В блоке `{foreachelse}...{/foreach}` использование `{break}`, `{continue}` выбросит исключение `Fenom\CompileException` при компиляции
|
||
|
||
**Замечание:**
|
||
Использование last требует от `$list` быть **countable**. |