{foreach}, {foreachelse}
Die foreach Schleife ist eine Alternative zu
section.
foreach wird verwendet, um ein assoziatives
Array zu durchlaufen. Die Syntax von
foreach-Schleifen ist viel einfacher als die
von section. {foreach}
Tags müssen mit {/foreach} tags kombiniert
werden. Erforderliche Parameter sind: from und
item. Der Name der {foreach}-Schleife kann
frei vergeben werden und sowohl Buchstaben, Zahlen als auch
Unterstriche enthalten. foreach-Schleifen
können verschachtelt werden, dabei ist zu beachten, dass sich die
definierten Namen voneinander unterscheiden. Die
from Variable (normalerweise ein assoziatives
Array) definiert die Anzahl der von foreach zu
durchlaufenen Iterationen. foreachelse wird
ausgeführt wenn keine Werte in der from
Variable übergeben wurden.
Attribut NameTypErforderlichStandardwertBeschreibungfromstringJan/aName des zu durchlaufenden Array.itemstringJan/aName für das aktuelle Element.keystringNeinn/aName für den aktuellen Schlüssel.namestringNeinn/aName der 'foreach'-Schleife, für die Abfrage der 'foreach'-Eigenschaften.{foreach} - item
assign('custid', $arr);
?>
]]>
{/foreach}
]]>
Das obige Beispiel erzeugt folgende Ausgabe:
id: 1001
id: 1002
]]>
{foreach} - item und key
assign('kontakte', array(
array('phone' => '1',
'fax' => '2',
'cell' => '3'),
array('phone' => '555-4444',
'fax' => '555-3333',
'cell' => '760-1234')
));
?>
]]>
{foreach key=schluessel item=wert from=$kontakt}
{$schluessel}: {$wert}
{/foreach}
{/foreach}
Das obige Beispiel erzeugt folgende Ausgabe:
phone: 1
fax: 2
cell: 3
phone: 555-4444
fax: 555-3333
cell: 760-1234
]]>
{foreach} - Beispiel mit Datenbankzugriff (z.B. PEAR oder ADODB)
assign('kontakte', $db->getAssoc($sql));
?>
]]>
{$con.name} - {$con.nick}
{/foreach}
]]>
Foreach-Loops haben auch eigene Variablen welche die Foreach
Eigenschaften enthalten. Diese werden wie folgt ausgewiesen:
{$smarty.foreach.foreachname.varname}. foreachname ist der Name der
als name Attribut von Foreach übergeben wurden.
iteration
gibt die aktuelle iteration aus
iteration beginnt immer mit 1 und wird danach bei jedem durchgang um 1 inkrementiert.
firstfirst ist TRUE wenn die aktuelle Iteration die erste ist
lastlast ist TRUE wenn die aktuelle Iteration die letzte ist
showshow wird als Parameter von foreach verwedet
und ist ein boolscher Wert, TRUE oder FALSE. Auf FALSE wird nichts
ausgegeben und wenn foreachelse gefunden wird, dieser angezeigt.
totaltotal gibt die Anzahl Iterationen des Foreach
Loops aus und kann in- oder nach- Foreach Blöcken verwendet werden.