Templates: Unterschied zwischen den Versionen

Aus DynPG-Wiki
Wechseln zu: Navigation, Suche
(Artikel überarbeitet und Template-Referenz ausgelagert)
Zeile 47: Zeile 47:
 
</code>
 
</code>
  
Im ordner dem Ordner '''''/tpl/MyCMS/minimal''''' wurde ein eigenes Template angelegt. In diesen Ordner verschieben wir eine Datei '''detail.tpl'', die obigen Inhalt aufweist. Damit haben wir uns eine eigene Artikel-Detailansicht definiert, die jetzt jederzeit in irgendeiner Seite verwendet werden kann, idnem folgender Cod eingefügt wird.
+
Im ordner dem Ordner "/tpl/MyCMS/minimal" wurde ein eigenes Template angelegt. In diesen Ordner verschieben wir eine Datei '''detail.tpl'', die obigen Inhalt aufweist. Damit haben wir uns eine eigene Artikel-Detailansicht definiert, die jetzt jederzeit in irgendeiner Seite verwendet werden kann, indem folgender Code eingefügt wird:
 
<code>[php,N]
 
<code>[php,N]
 
$DynPG->setupTemplate("minimal");
 
$DynPG->setupTemplate("minimal");
Zeile 55: Zeile 55:
 
$DynPG->Write_Article();
 
$DynPG->Write_Article();
 
</code>
 
</code>
<tt>{$CONTENT}</tt> ist ein Platzhalter für den Inhalt des anzuzeigenden Artikels. An dieser Stelle wird dann also der eigentliche Artikeltext eingefügt (das macht die Templateengine). Eine Liste der Templatevariablen (Platzhalter) finden Sie im nächsten [[#Liste und Bedeutung der Template-Variablen|Kapitel]].  
+
<tt>{$CONTENT}</tt> ist ein Platzhalter für den Inhalt des anzuzeigenden Artikels. An dieser Stelle wird dann also der eigentliche Artikeltext eingefügt (genau das erledigt die Templateengine). Eine Liste der Templatevariablen (Platzhalter) finden Sie in der  [[Template-Referenz]].  
  
Die Templatesprache hat neben den Templateplatzhaltern noch 2 andere wichtige Sprachelemente. Dies wäre zum einen die [[#Die bedingte Anweisung|bedingte Anweisung]] und zum anderen ein [[#PHP-Code|PHP-Block]], der es ermöglicht PHP-Anweisungen auszuführen. In die Template-Datei kann zudem auch beliebiger HTML-Code eingefügt werden, wodurch den Gestaltungsphantasien fast keine Grenzen gesetzt sind!
+
Die Templatesprache hat neben den Templateplatzhaltern noch 2 andere wichtige Sprachelemente. Dies sind die [[#Die bedingte Anweisung|bedingte Anweisung]] und der [[#PHP-Code|PHP-Block]], der es ermöglicht PHP-Anweisungen auszuführen. In die Template-Datei kann zudem auch beliebiger HTML-Code eingefügt werden, wodurch die Gestaltungsmöglichkeiten noch vielfältiger werden.
 
+
=== Liste und Bedeutung der Template-Variablen ===
+
Dieses Template ist zuständig für die Darstellung von Ansichten der Gruppen-Listen.
+
 
+
{| class="dynpgwikitable"
+
|+ Templatevariablen - groups.tpl
+
! <center>Platzhalter</center>
+
! <center>Beschreibung</center>
+
 
+
|-
+
| {$ROOT_NAVIGATION}
+
| Erstellt eine Übersichts-Navigation. Gruppe >> Untergruppe
+
 
+
|-
+
| {$PAGES_NAVIGATION}
+
| Erstellt eine Navigation zum Blättern bei mehreren Seiten. Also falls mehr Gruppen angezeigt werden sollten, als in der config.php unter config_AllGroups_Limit eingestellt sind.
+
 
+
|-
+
| {$LIST_REFER_TO}
+
| Enthält die URL-Adresse zur nächsttieferen Anzeige- Stufe (im falle groups.tpl den Link zur Artikelliste oder zur Untergruppe).
+
 
+
|-
+
| {$NAME}
+
| Gibt den Namen der Gruppe aus.
+
 
+
|-
+
| {$SHORTTEXT}
+
| Gibt den Kurztext der Gruppe aus.
+
 
+
|-
+
| {$CREATEDATE}
+
| Gibt das Erstelldatum der Gruppe aus.
+
 
+
|-
+
| {$LIST_SHOW_VISTS}
+
| Gibt die Anzahl Klicks auf den Link der entsprechenden Gruppe aus.
+
 
+
|-
+
| {$LIST_HAS_IMAGE}
+
| Gibt zurück, ob die Gruppe ein Leadbild hat. Falls ja wird TRUE, bei nein FALSE zurückgegeben. Entnimmt den Wert aus DynPG.
+
 
+
|-
+
| {$LIST_IMAGE_ALIGN}
+
| Gibt die gewünschte Position des Leadbildes zurück. TOP für oben, BOTTOM für unten, LEFT für links und RIGHT für rechts. Entnimmt den Wert aus DynPG.
+
 
+
|-
+
| {$IMAGE_URL}
+
| Gibt das Quellverzeichnis des Leadbildes aus.
+
 
+
|-
+
| {$IMAGE_NAME}
+
| Gibt den Namen des Leadbildes aus.
+
 
+
|-
+
| {$IMAGE_DESCR}
+
| Gibt die Beschreibung des Leadbildes aus.
+
 
+
|}
+
 
+
 
+
Dieses Template ist zuständig für die Darstellung von Ansichten der Artikel-Listen.
+
 
+
{| class="dynpgwikitable"
+
|+ Templatevariablen - articles.tpl
+
! <center>Platzhalter</center>
+
! <center>Beschreibung</center>
+
 
+
|-
+
| {$ROOT_NAVIGATION}
+
| Erstellt eine Übersichts-Navigation. Gruppe >> Artikel
+
 
+
|-
+
| {$PAGES_NAVIGATION}
+
| Erstellt eine Navigation zum Blättern bei mehreren Seiten. Also falls Sie mehr Gruppen angezeigt werden sollten, als in der config.php unter 'config_AllArticles_Limit' eingestellt sind.
+
 
+
|-
+
| {$LIST_USER_DEFINED_CSS}
+
| Gibt den Wert zurück, den Sie beim Implementieren unter SetParam_AA_SingleCss(...); angegeben wurde.
+
 
+
|-
+
| {$LIST_INDEX}
+
| Gibt die aktuelle Anzahl (den Index) der angezeigten Artikel zurück (also beim 3. Artikel den Wert 3, beim 6. Artikel den Wert 6).
+
 
+
|-
+
| {$LIST_REFER_TO}
+
| Enthält die URL-Adresse zur nächsttieferen Anzeige- Stufe (im falle articles.tpl den Link zur Detail-Ansicht).
+
 
+
|-
+
| {$CONTENT}
+
| Gibt die ID des zum Artikel gehörigen Textes aus.
+
 
+
|-
+
| {$TITLE}
+
| Gibt den Namen/Titel des Artikels aus.
+
 
+
|-
+
| {$LEAD}
+
| Gibt den Lead-Text des Artikels aus.
+
 
+
|-
+
| {$SHOWDATE}
+
| Gibt zurück, ob das Erstelldatum angezeigt werden soll. Falls ja wird TRUE, bei nein FALSE zurückgegeben. Entnimmt den Wert aus DynPG.
+
 
+
|-
+
| {$CREATEDATE}
+
| Gibt das Erstelldatum des Artikels aus
+
 
+
|-
+
| {$LIST_SHOW_VISTS}
+
| Gibt die Anzahl Klicks auf den Link des entsprechenden Artikel aus.
+
 
+
|-
+
| {$LIST_HAS_IMAGE}
+
| Gibt zurück, ob der Artikel ein Leadbild hat. Falls ja wird TRUE, bei nein FALSE zurückgegeben. Entnimmt den Wert aus DynPG.
+
 
+
|-
+
| {$LIST_IMAGE_ALIGN}
+
| Gibt die gewünschte Position des Leadbildes zurück. TOP für oben, BOTTOM für unten, LEFT für links und RIGHT für rechts. Entnimmt den Wert aus DynPG.
+
 
+
|-
+
| {$IMAGE_URL}
+
| Gibt das Quellverzeichnis des Leadbildes aus.
+
 
+
|-
+
| {$IMAGE_NAME}
+
| Gibt den Namen des Leadbildes aus.
+
 
+
|-
+
| {$IMAGE_DESCR}
+
| Gibt die Beschreibung des Leadbildes aus.
+
 
+
|}
+
 
+
 
+
Dieses Template ist zuständig für die Darstellung der Detailansicht eines Artikels.
+
 
+
{| class="dynpgwikitable"
+
|+ Templatevariablen - detail.tpl
+
! <center>Platzhalter</center>
+
! <center>Beschreibung</center>
+
 
+
|-
+
| {$COND_SEGM_CATNAV}
+
| Gibt zurück, ob eine Übersichts-Navigation angezeigt werden soll. Falls ja wird TRUE, bei nein FALSE zurückgegeben. Entnimmt den Wert aus der Implementation: SetParam_A_CategoryNavigation(TRUE/FALSE);
+
 
+
|-
+
| {$ROOT_NAVIGATION}
+
| Erstellt eine Übersichts-Navigation . Gruppe >> Artikel >> Titel
+
 
+
|-
+
| {$LIST_USER_DEFINED_CSS}
+
| Gibt den Wert zurück, den Sie beim Implementieren unter SetParam_A_ArticleCss(...); angegeben wurde.
+
 
+
|-
+
| {$COND_SEGM_HEAD}
+
| Gibt zurück, ob der Head-Bereich (im Normalfall Headtext und Beschreibung) angezeigt werden soll. Falls ja wird TRUE, bei nein FALSE zurückgegeben. Entnimmt den Wert aus der Implementation: SetParam_A_ArticleHeader(TRUE/FALSE);
+
 
+
|-
+
| {$TITLE}
+
| Gibt den Namen/Titel des Artikels aus.
+
 
+
|-
+
| {$LEAD}
+
| Gibt den Lead-Text des Artikels aus.
+
 
+
|-
+
| {$SHOWDATE}
+
| Gibt zurück, ob das Erstelldatum angezeigt werden soll. Falls ja wird TRUE, bei nein FALSE zurückgegeben. Entnimmt den Wert aus DynPG.
+
 
+
|-
+
| {$CREATEDATE}
+
| Gibt das Erstelldatum des Artikels aus
+
 
+
|-
+
| {$COND_SEGM_TEXT}
+
| Gibt zurück, ob der Artikelinhalt/-text angezeigt werden soll. Falls ja wird TRUE, bei nein FALSE zurückgegeben. Entnimmt den Wert aus der Implementation: SetParam_A_ShowText(TRUE/FALSE);
+
 
+
|-
+
| {$CONTENT}
+
| Gibt den zugehörigen Text des Artikels aus
+
 
+
|-
+
| {$COND_SEGM_PRINTNAV}
+
| Gibt zurück, ob ein Link um den Artikel zu drucken angezeigt werden soll. Falls ja wird TRUE, bei nein FALSE zurückgegeben. Entnimmt den Wert aus der Implementation: SetParam_A_PrintNavigation(TRUE/FALSE);
+
 
+
|-
+
| {$PRINT_HREF}
+
| Gibt den Link zur Druckansicht des Artikels aus.
+
 
+
|-
+
| {$COND_SEGM_SEPARATOR}
+
| Gibt zurück, ob der Seperator im Text ignoriert werden soll. Falls ja wird TRUE, bei nein FALSE zurückgegeben. Entnimmt den Wert aus der Implementation: SetParam_A_IgnoreSeperator(TRUE/FALSE);
+
 
+
|-
+
| {$MORE_HREF}
+
| Gibt die URL aus, die vom durch den Seperator getrennten Text zum gesamten Text führt.
+
 
+
|}
+
 
+
 
+
Dieses Template ist zuständig für die Darstellung der Home-Ansicht.
+
 
+
{| class="dynpgwikitable"
+
|+ Templatevariablen - home.tpl
+
! <center>Platzhalter</center>
+
! <center>Beschreibung</center>
+
 
+
|-
+
| {$LIST_INDEX}
+
| Gibt die aktuelle Anzahl (den Index) der angezeigten Artikel zurück (also beim 3. Artikel den Wert 3, beim 6. Artikel den Wert 6).
+
 
+
|-
+
| {$GRP_NAME}
+
| Gibt den Gruppennamen aus.
+
 
+
|-
+
| {$LIST_HEADER_EACH}
+
| &nbsp;
+
 
+
|-
+
| {$TITLE}
+
| Gibt den Namen/Titel des Artikels aus.
+
 
+
|-
+
| {$LEAD}
+
| Gibt den Lead-Text des Artikels aus.
+
 
+
|-
+
| {$LIST_SHOWTEXT_EACH}
+
| &nbsp;
+
 
+
|-
+
| {$CONTENT}
+
| Gibt den zugehörigen Text des Artikels aus.
+
 
+
|-
+
| {$SHOWDATE}
+
| Gibt zurück, ob das Erstelldatum angezeigt werden soll. Falls ja wird TRUE, bei nein FALSE zurückgegeben. Entnimmt den Wert aus DynPG.
+
 
+
|-
+
| {$CREATEDATE}
+
| Gibt das Erstelldatum des Artikels aus.
+
 
+
|-
+
| {$LIST_FWD_TEXT}
+
| &nbsp;
+
 
+
|-
+
| {$LIST_REFER_TO}
+
| Enthält die URL-Adresse zur nächsttieferen Anzeige- Stufe (im falle home.tpl den Link zum gesamten Artikel).
+
 
+
|}
+
 
+
 
+
Dieses Template ist zuständig für die Darstellung von Ansichten der Artikel-Listen.
+
 
+
{| class="dynpgwikitable"
+
|+ Templatevariablen - navigation-page.tpl
+
! <center>Platzhalter</center>
+
! <center>Beschreibung</center>
+
 
+
|-
+
| {$PG_NAV_LASTPAGE}
+
| Gibt die Seitenzahl der Seite davor aus.
+
 
+
|-
+
| {$PG_NAV_NEXTPAGE}
+
| Gibt die Seitenzahl der nächsten Seite aus.
+
 
+
|-
+
| {$PG_NAV_RELPAGE}
+
| Gibt die URL der Seite aus.
+
 
+
|-
+
| {$PG_NAV_SEPARATION}
+
| &nbsp;
+
 
+
|-
+
| {$PG_NAV_ISCURRENT}
+
| &nbsp;
+
 
+
|}
+
 
+
 
+
Dieses Template ist zuständig für die Darstellung von Ansichten der Artikel-Listen.
+
 
+
{| class="dynpgwikitable"
+
|+ Templatevariablen - search-form.tpl
+
! <center>Platzhalter</center>
+
! <center>Beschreibung</center>
+
 
+
|-
+
| {$SEARCH_RESULTPAGE}
+
| Gibt die URL der Seite aus, auf der die Suchresultate erscheinen.
+
 
+
|}
+
  
 
=== Die bedingte Anweisung ===
 
=== Die bedingte Anweisung ===
 
Folgendes Beispiel zeigt, wie man bedingte Anweisungen in seine Templates integrieren kann:  
 
Folgendes Beispiel zeigt, wie man bedingte Anweisungen in seine Templates integrieren kann:  
  
'''Beispiel 2.2. Template-Beispiel (Artikel-Detailansicht mit bedingter Anweisung)'''
+
'''Template-Beispiel''' (Artikel-Detailansicht mit bedingter Anweisung)
  
 
<code>[html,N]
 
<code>[html,N]
Zeile 379: Zeile 83:
 
{$# End #}
 
{$# End #}
 
</code>
 
</code>
Hier wird der Text '''''"mein Lieblingsartikel!"''''' nur dann ausgegeben, wenn der Artikel den Namen "Kontakt" trägt. Die Syntax für bedingte Anweisungen lautet allgemein:  
+
Hier wird der Text <tt>"mein Lieblingsartikel!"</tt> nur dann ausgegeben, wenn der Artikel den Namen "Kontakt" trägt. Die Syntax für bedingte Anweisungen lautet allgemein:  
 
<code>[html,N]
 
<code>[html,N]
 
{$#(Bedingung) #}
 
{$#(Bedingung) #}
Zeile 388: Zeile 92:
 
</code>
 
</code>
  
[[Image:caution.png]] '''Achtung''' Bei Zeichenkettenvergleichen(wie in obigem Bsp.) muss darauf geachtet werden, dass auch die Templatevariablen von Anführungszeichen umgeben werden, sonst hagelt es Fehlerausschriften!
+
[[Image:caution.png]] '''Achtung:''' Bei Zeichenkettenvergleichen (wie in obigem Bsp.) muss darauf geachtet werden, dass auch die Templatevariablen von Anführungszeichen umgeben werden, sonst hagelt es Fehlerausschriften.
  
[[Image:tip.png]] '''Tipp''' Die Bedingung wird als PHP-Code ausgewertet, daher können prinzipiell alle Operatoren verwendet werden, solange der Ergebnisausdruck einen Wahrheitswert liefert.
+
[[Image:tip.png]] '''Tipp:''' Die Bedingung wird als PHP-Code ausgewertet, daher können prinzipiell alle Operatoren verwendet werden, solange der Ergebnisausdruck einen Wahrheitswert liefert.
  
 
Schauen wir uns ein Beispiel mit Negation an.
 
Schauen wir uns ein Beispiel mit Negation an.
Zeile 428: Zeile 132:
 
einer PHP-Seite gleich. Auch hier ein kleines Beispiel:  
 
einer PHP-Seite gleich. Auch hier ein kleines Beispiel:  
  
'''Beispiel 2.3. Template-Beispiel (Artikel-Detailansicht mit PHP-Code)'''
+
'''Template-Beispiel''' (Artikel-Detailansicht mit PHP-Code)
  
 
<code>[html,N]
 
<code>[html,N]
Zeile 438: Zeile 142:
 
</code>
 
</code>
  
[[Image:caution.png]] '''Achtung''' Am Ende eines PHP-Statements '''''darf kein Semikolon (";")''''' stehen, wie sonst üblich!
+
[[Image:caution.png]] '''Achtung:''' Am Ende eines PHP-Statements '''''darf kein Semikolon (";")''''' stehen, wie sonst üblich!
  
 
== Diese Informationen als PDF ==
 
== Diese Informationen als PDF ==
 
Teile dieses Artikels sind auch in [[Media:Templates.pdf|Templates.pdf]] enthalten. Diese Datei wird jedoch wahrscheinlich nicht mehr aktualisiert und ist damit nicht so aktuell wie dieser Artikel.
 
Teile dieses Artikels sind auch in [[Media:Templates.pdf|Templates.pdf]] enthalten. Diese Datei wird jedoch wahrscheinlich nicht mehr aktualisiert und ist damit nicht so aktuell wie dieser Artikel.

Version vom 9. Mai 2010, 13:16 Uhr

Einführung

Mit DynPG ist es möglich die Art und Weise wie Artikel und Listenansichten ausgegeben werden, zu beeinflussen. Ein Weg ist CSS, ein anderer (wesentlich flexiblerer) geht über die eingebaute Template-Engine. Ein Beispiel: Der Aufruf

$DynPG->Write_Article();

bewirkt, dass die Detailansicht eines Artikels angezeigt wird. Dabei wird (wenn nichts anderes explizit angegeben wurde) implizit ein Standard-Template verwendet, das definiert wie diese Ansicht auszusehen hat. Im DynPG-Unterverzeichnis "/tpl/MyCMS/default/" liegen die Templatedateien für die Standardansichten.

  • groups.tpl: Gruppenlistenansicht
  • articles.tpl: Artikellistenansicht
  • detail.tpl: Artikel-Detailansicht
  • home.tpl: Home-Ansicht
  • navigation.tpl: Blätterfunktion der Listen-Ansichten
  • search-form.tpl: Formular für die Suche

In diesen Dateien haben Sie die Möglichkeit, oben genannte Ansichten nach Ihren Wünschen anzupassen. Die Darstellung geschieht grundsätzlich mit HTML. Zusätzlich gibt es eine Templatesprache. Diese ist schlicht gehalten und beinhaltet einige wenige Elemente die nachfolgend näher betrachtet werden sollen. Statt die Standard-Templates zu manipulieren, können auch neue Templates erzeugt werden. Dazu muss im Unterverzeichnis "/tpl/MyCMS/" einfach ein neuer Ordner mit dem gewünschten Templatenamen angelegt werden. Je nachdem welche Ansichten nun geändert werden sollen, fügt man Dateien mit denselben Namen wie in oben genannter Liste ein. Diese können dann nach den eigenen Wünschen bearbeitet werden. Mit den Zeilen

$DynPG->setupTemplate("meinTemplate");
 
$DynPG->SetParam_A_Article(13);
 
$DynPG->Write_Article();
 
$DynPG->setupTemplate("default");

wird das Template meinTemplate gesetzt und damit der Artikel 13 ausgegeben.


Caution.png Achtung: Das Setzen eines Templates muss vor der Ausgabe des Artikels erfolgen!

Caution.png Achtung: Wenn das Template gesetzt wurde, dann wird es auch für alle nachfolgenden Ausgaben verwendet! Ist dies unerwünscht, muss man explizit wieder das Standard-Template(default) setzen.

Die Template-Sprache

Ein erstes kleines Beispiel

Hier ein kleines einführendes Beispiel:

Template-Minimalbeispiel (eigene Artikel-Detailansicht in "/tpl/MyCMS/minimal/detail.tpl")

<!-- Dies ist ein Kommentar (er wird nicht angezeigt) -->
{$CONTENT} <!--Den Inhalt des Artikels ausgeben--> 
 
Dies ist ein <b>selbstdefiniertes Template</b>  <!--beliebiger HTML-Code-->
 
<!--Alles was hier drinsteht, wird nach dem Aufruf von $DynPG->Write_Article(); eingefügt -->

Im ordner dem Ordner "/tpl/MyCMS/minimal" wurde ein eigenes Template angelegt. In diesen Ordner verschieben wir eine Datei 'detail.tpl, die obigen Inhalt aufweist. Damit haben wir uns eine eigene Artikel-Detailansicht definiert, die jetzt jederzeit in irgendeiner Seite verwendet werden kann, indem folgender Code eingefügt wird:

$DynPG->setupTemplate("minimal");
 
$DynPG->SetParam_A_Article(13);
 
$DynPG->Write_Article();

{$CONTENT} ist ein Platzhalter für den Inhalt des anzuzeigenden Artikels. An dieser Stelle wird dann also der eigentliche Artikeltext eingefügt (genau das erledigt die Templateengine). Eine Liste der Templatevariablen (Platzhalter) finden Sie in der Template-Referenz.

Die Templatesprache hat neben den Templateplatzhaltern noch 2 andere wichtige Sprachelemente. Dies sind die bedingte Anweisung und der PHP-Block, der es ermöglicht PHP-Anweisungen auszuführen. In die Template-Datei kann zudem auch beliebiger HTML-Code eingefügt werden, wodurch die Gestaltungsmöglichkeiten noch vielfältiger werden.

Die bedingte Anweisung

Folgendes Beispiel zeigt, wie man bedingte Anweisungen in seine Templates integrieren kann:

Template-Beispiel (Artikel-Detailansicht mit bedingter Anweisung)

<!--Wenn Artikelname = "Kontakt" dann Inhalt + zusätzliche Infos ausgeben-->
 
{$# ('{$TITLE}'=='Kontakt') #}
 
{$CONTENT}
 
mein <b>Lieblingsartikel</b>!
 
{$# End #}
 
<!--andernfalls nur den Inhalt ausgeben-->
 
{$# ('{$TITLE}'!='Kontakt') #}
 
{$CONTENT}
 
{$# End #}

Hier wird der Text "mein Lieblingsartikel!" nur dann ausgegeben, wenn der Artikel den Namen "Kontakt" trägt. Die Syntax für bedingte Anweisungen lautet allgemein:

{$#(Bedingung) #}
 
...
 
{$# End #}

Caution.png Achtung: Bei Zeichenkettenvergleichen (wie in obigem Bsp.) muss darauf geachtet werden, dass auch die Templatevariablen von Anführungszeichen umgeben werden, sonst hagelt es Fehlerausschriften.

Tip.png Tipp: Die Bedingung wird als PHP-Code ausgewertet, daher können prinzipiell alle Operatoren verwendet werden, solange der Ergebnisausdruck einen Wahrheitswert liefert.

Schauen wir uns ein Beispiel mit Negation an.

<table>
    <tr>
      <td> {$TITLE} </td>
    </tr>
  {$# ({$SHOWDATE}) #}
    <tr>
      <td> Erstellt am: {$CREATEDATE} </td>
    </tr>
  {$# End #}
  {$# (!{$SHOWDATE}) #}
    <tr>
      <td> Anzeige ohne Erstelldatum </td>
    </tr>
  {$# End #}
    <tr>
      <td> {$CONTENT} </td>
    </tr>
</table>

Das obige Beispiel gibt den Artikel mit seinem Erstelldatum aus, falls das entsprechende Häkchen im Backend angeklickt wurde, ansonsten wird "Anzeige ohne Erstelldatum" ausgegeben.

PHP-Code

{$#PHP (PHP-CODE) #}

Mit dieser Syntax können Sie PHP-Code implementieren. Alles was in der Klammer steht, wird als PHP-Code interpretiert. Es kommt dem Tag

<?php ... ?>

einer PHP-Seite gleich. Auch hier ein kleines Beispiel:

Template-Beispiel (Artikel-Detailansicht mit PHP-Code)

<!--Zeichenlänge des Titels anzeigen-->
 
Die Länge des Titels beträgt {$#PHP (strlen("{$TITLE}")) #} Zeichen 
 
{$CONTENT} <!--Inhalt ausgeben-->

Caution.png Achtung: Am Ende eines PHP-Statements darf kein Semikolon (";") stehen, wie sonst üblich!

Diese Informationen als PDF

Teile dieses Artikels sind auch in Templates.pdf enthalten. Diese Datei wird jedoch wahrscheinlich nicht mehr aktualisiert und ist damit nicht so aktuell wie dieser Artikel.