For: Unterschied zwischen den Versionen
(Die Seite wurde neu angelegt: „Mit dem for-Tag kann man in AOQML Schleifen erstellen. Dies kann insbesondere bei Gruppenoptionen sowie zur einfacheren Handhabung komplexer Szenen hilfrei…“) |
(→Gruppenmitglieder durchgehen) |
||
Zeile 41: | Zeile 41: | ||
<p>HeldID: <fetch name="heldid"/>, Name: <get attribute="name"/></p> | <p>HeldID: <fetch name="heldid"/>, Name: <get attribute="name"/></p> | ||
</for> | </for> | ||
+ | <!-- Hinweis: jetzt ist nur noch der zuletzt ausgegebene Held selektiert (da mehrere einzelne Selects durchgeführt wurden) --> | ||
</code> | </code> | ||
Zeile 46: | Zeile 47: | ||
Möchte man auf die bereits selektierten Gruppenmitglieder zugreifen, kann die Variable ''sys:selected-heroes'' verwendet werden.<br /> | Möchte man auf die bereits selektierten Gruppenmitglieder zugreifen, kann die Variable ''sys:selected-heroes'' verwendet werden.<br /> | ||
Möchte man auf die bisher nichtselektierten Gruppenmitglieder zugreifen, kann die Variable ''sys:unselected-heroes'' verwendet werden. | Möchte man auf die bisher nichtselektierten Gruppenmitglieder zugreifen, kann die Variable ''sys:unselected-heroes'' verwendet werden. | ||
+ | |||
+ | <code xml> | ||
+ | <!-- alle Helden ausgeben, die gerade selektiert sind --> | ||
+ | <for all="${sys:selected-heroes}" name="heldid"> | ||
+ | <select hero="${heldid}"/> | ||
+ | <p>HeldID: <fetch name="heldid"/>, Name: <get attribute="name"/></p> | ||
+ | </for> | ||
+ | <!-- Hinweis: jetzt ist nur noch der zuletzt ausgegebene Held selektiert (da mehrere einzelne Selects durchgeführt wurden) --> | ||
+ | </code> | ||
[[Kategorie:AOQML-Tags]] | [[Kategorie:AOQML-Tags]] | ||
[[Kategorie:AOQML]] | [[Kategorie:AOQML]] |
Version vom 26. Oktober 2013, 20:48 Uhr
Mit dem for-Tag kann man in AOQML Schleifen erstellen. Dies kann insbesondere bei Gruppenoptionen sowie zur einfacheren Handhabung komplexer Szenen hilfreich sein.
Inhaltsverzeichnis
Syntax
<for all="" name="">
<!-- Schleifenrumpf -->
</for>
Attribut | Erklärung |
---|---|
all | Hier wird das Array angegeben, über das iteriert werden soll. Als Trenner zwischen den Array-Elementen wird | benutzt. |
name | Gibt den Bezeichner der Variable an, die bei jedem Schleifendurchlauf mit dem neuen Array-Element gesetzt wird. Die Variable hat den Scope 'scene'. |
Das, was im Schleifenrumpf angegeben ist, wird für jedes Array-Element ausgeführt.
Beispiele
Mehrere Proben hintereinander durchführen
Im folgenden Beispiel werden drei Talentproben hintereinander durchgeführt.
<for all="Singen|Schleichen|Schwimmen" name="tal">
<challenge talent="${tal}">
</challenge>
</for>
Gruppenmitglieder durchgehen
Im folgenden Beispiel wird über alle Gruppenmitglieder iteriert. Im Schleifenrumpf wird jeder Held wird einzeln selektiert und seine HeldID und sein Name ausgegeben.
<for all="${sys:heroes}" name="heldid">
<select hero="${heldid}"/>
<p>HeldID: <fetch name="heldid"/>, Name: <get attribute="name"/></p>
</for>
<!-- Hinweis: jetzt ist nur noch der zuletzt ausgegebene Held selektiert (da mehrere einzelne Selects durchgeführt wurden) -->
Die Variable sys:heroes hat alle Held-IDs der Gruppenmitglieder gespeichert.
Möchte man auf die bereits selektierten Gruppenmitglieder zugreifen, kann die Variable sys:selected-heroes verwendet werden.
Möchte man auf die bisher nichtselektierten Gruppenmitglieder zugreifen, kann die Variable sys:unselected-heroes verwendet werden.
<!-- alle Helden ausgeben, die gerade selektiert sind -->
<for all="${sys:selected-heroes}" name="heldid">
<select hero="${heldid}"/>
<p>HeldID: <fetch name="heldid"/>, Name: <get attribute="name"/></p>
</for>
<!-- Hinweis: jetzt ist nur noch der zuletzt ausgegebene Held selektiert (da mehrere einzelne Selects durchgeführt wurden) -->