Die Template Attribute Language Expression Syntax (TALES) beschreibt die Syntax für die Auswertung der von der Template Attribute Language (TAL) und Macro Expansion Template Attribute Language (METAL) für Attributwerte verwendeten Ausdrücke. Die Möglichkeit, hierfür eine andere Syntax als TALES zu verwenden, ist ausdrücklich vorgesehen; in der Regel wird TALES jedoch nicht ersetzt, sondern erweitert.
Der Webanwendungsserver Zope erweitert die TALES-Spezifikation im Rahmen der Zope Page Templates.
Überblick
TALES stellt mehrere Methoden zur Verfügung, Ausdrücke zu formulieren, die in TAL- und METAL-Attributen verwendet werden können und durch ein (optionales) Präfix unterschieden werden:
Ausdrucksarten
- Pfadausdruck
- Präfix
path:
(optional, und deshalb fast immer fortgelassen): zum Zugriff auf strukturierte Variablen, Dateisystemobjekte, Makros (METAL) usw. - Stringausdruck
- Präfix
string:
; erlaubt Pfadausdrücke in${...}
- Logische Negation
- Präfix
not:
; wertet den restlichen Ausdruck aus und gibt seine logische Negation zurück - Python-Ausdruck
- Präfix
python:
; wenn implementiert, gibt den Wert des folgenden Python-Ausdrucks zurück. Dies findet üblicherweise nur Anwendung, wenn Pfadausdrücke nicht ausreichen, z. B. wenn eine Funktion mit bestimmten Argumenten aufgerufen werden muss. - Unterdrückung des Quotings
- Das vorangestellte Schlüsselwort
structure
(ohne Doppelpunkt) unterdrückt das sonst automatisch angewendete HTML-Quoting, um beispielsweise ein komplettes HTML-Element zu erzeugen.
Eingebaute Namen
- nothing
- ein „Nicht-Wert“, der keine Zeichenkette sein darf, z. B. None (Programmiersprache Python), void, Nil, oder NULL.
- options
- die (benannten) Argumente, die dem Template übergeben wurden
- repeat
- zum Zugriff auf Schleifenvariablen wie index, number usw.
Diese Namen werden üblicherweise noch um weitere ergänzt, siehe Zope Page Templates.
Beispiele
Einfacher Pfadausdruck zum Zugriff auf ein Makro
<metal:form use-macro="location/page/MACROS/myform"/>
Hier sei beispielsweise location
das Verzeichnis, das eine Vorlagendatei page
enthält, in der wiederum das Makro myform
definiert wurde. In Zope Page Templates würde hier anstelle von location
z. B. here
(als Ausgangspunkt der Akquisition zur Suche nach page
) oder container
stehen.
Schleife mit Pfad-, Python- und Stringausdrücken
<tr tal:repeat="item python:({'key': 'eins'}, {'key': 'zwei'})"> <td tal:content="repeat/item/number">99</td> <td tal:content="string:Zeile ${item/key}">Zeile 99</td> </tr>
Ausgabe:
<tr> <td>1</td> <td>Zeile eins</td> </tr> <tr> <td>2</td> <td>Zeile zwei</td> </tr>
Erläuterungen:
- das
tal:repeat
-Attribut erzeugt eine Variableitem
und, mit Hilfe des Python-Ausdrucks, eine Sequenz von Dictionarys, die verwendet wird, um mehrere HTML-Tabellenzeilen zu erzeugen - die speziellen Schleifenvariablen (z. B. number) für
item
werden über die spezielle, vom TALES-Standard geforderte Variablerepeat
zur Verfügung gestellt - Pfadausdrücke können auch innerhalb von String-Ausdrücken verwendet werden
Logische Negation und TAL-Elemente
<div tal:define="view_ok context/is_view_ok"> <tal:if condition="view_ok"> ... </tal:if> <tal:else condition="not:view_ok"> ... </tal:else> </div>
is_view_ok könnte hier eine Methode sein, die aus dem context aufgerufen wird und die Leseberechtigung des Benutzers überprüft. Im „Else-Zweig“ (der syntaktisch nichts anderes ist als der „If-Zweig“; if
und else
sind hier frei gewählte Namen, die sogar hätten gleich sein dürfen) wird die logische Bedingung des If-Zweigs umgekehrt, sodass nur einer der beiden ausgeführt wird.
Siehe auch
- i18n TAL
- Template Engine
Weblinks
- TALES-Spezifikation, Version 1.3
- Schleifenvariablen (Memento vom 9. September 2012 im Internet Archive)
- TALES Overview (im Zope-Book)
- TALES-Seite im Zope-3-Wiki (Memento vom 14. September 2011 im Internet Archive)