Vorlagen templates
Vorlagen werden an verschiedenen Stellen in AEM verwendet:
-
Wenn Sie eine Seite erstellen, wählen Sie eine Vorlage aus. Diese Vorlage wird als Basis für die neue Seite verwendet. Die Vorlage definiert die Struktur der Seite, jeden anfänglichen Inhalt und die Komponenten, die verwendet werden können (Design-Eigenschaften).
-
Beim Erstellen eines Inhaltsfragments wählen Sie auch eine Vorlage aus. Diese Vorlage definiert die Struktur, die Anfangselemente und die Variationen.
Die folgenden Vorlagen werden im Detail beschrieben:
Vorlagen – Seiten templates-pages
AEM bietet jetzt zwei grundlegende Arten von Vorlagen zum Erstellen von Seiten:
Bearbeitbare Vorlagen editable-templates
Bearbeitbare Vorlagen gelten nun als Best Practices für die Entwicklung mit AEM.
Die Vorteile bearbeitbarer Vorlagen:
-
Können von den Autoren oder Autorinnen erstellt und bearbeitet werden.
-
Wurden eingeführt, damit Sie Folgendes für alle Seiten definieren können, die mit der Vorlage erstellt werden:
- Die Struktur
- Den anfänglichen Inhalt
- Inhaltsrichtlinien
-
Nachdem die neue Seite erstellt wurde, wird eine dynamische Verbindung zwischen der Seite und der Vorlage aufrechterhalten. Diese Verbindung bedeutet, dass Änderungen an der Vorlagenstruktur auf allen Seiten widergespiegelt werden, die mit dieser Vorlage erstellt werden. Änderungen am anfänglichen Inhalt werden nicht übernommen.
-
Verwendet Inhaltsrichtlinien (die im Vorlageneditor bearbeitet wurden), um die Designeigenschaften beizubehalten (verwendet den Designmodus im Seiteneditor nicht).
-
Werden gespeichert unter
/conf
-
Siehe Bearbeitbare Vorlagen für weitere Informationen.
Statische Vorlagen static-templates
Statische Vorlagen:
- Muss von Ihren Entwickelnden definiert und konfiguriert werden.
- Das ursprüngliche Vorlagensystem von AEM, das seit vielen Versionen verfügbar ist.
- Eine statische Vorlage ist eine Hierarchie von Knoten mit derselben Struktur wie die zu erstellende Seite, jedoch ohne tatsächlichen Inhalt.
- Werden kopiert, um die Seite zu erstellen. Danach existiert keine dynamische Verbindung.
- Verwendet Design-Modus, um Design-Eigenschaften zu persistieren.
- Werden gespeichert unter
/apps
- Siehe Statische Vorlagen für weitere Informationen.
Verfügbarkeit von Vorlagen template-availability
-
nur die
cq:allowedTemplates
-Eigenschaft -
nur im Site-Stamm
/content/we-retail/jcr:content
allowedPaths
, allowedParents
und allowedChildren
in den Vorlagen platziert werden, um komplexere Regeln zu definieren. Wenn möglich, ist es jedoch viel einfacher, weitere cq:allowedTemplates
-Eigenschaften auf Unterabschnitten der Site zu definieren, wenn es notwendig ist, die erlaubten Vorlagen weiter einzuschränken.cq:allowedTemplates
-Eigenschaften von einem Autor oder einer Autorin auf der Registerkarte Erweitert der Seiteneigenschaften aktualisiert werden können. Die anderen Vorlageneigenschaften können nicht über die (standardmäßige) Benutzeroberfläche aktualisiert werden. Dafür wird ein Entwickler bzw. eine Entwicklerin benötigt, der bzw. die die Regeln und Code-Implementierung für jede Änderung pflegt.Beim Erstellen einer neuen Seite in der Site-Admin-Oberfläche hängt die Liste der verfügbaren Vorlagen vom Speicherort der neuen Seite und den in den einzelnen Vorlagen angegebenen Platzierungsbeschränkungen ab.
Die folgenden Eigenschaften bestimmen, ob eine T
-Vorlage für eine neue Seite verwendet wird, die als untergeordnetes Element der Seite P
platziert werden soll. Jede dieser Eigenschaften ist eine mehrwertige Zeichenfolge, welche null oder mehrere reguläre Ausdrücke enthält, die für die Übereinstimmung mit Pfaden verwendet werden:
-
Die Eigenschaft
cq:allowedTemplates
des Unterknotensjcr:content
vonP
oder ein Vorgänger vonP
. -
Die
allowedPaths
-Eigenschaft vonT
. -
Die
allowedParents
-Eigenschaft vonT
. -
Die
allowedChildren
-Eigenschaft der Vorlage vonP
.
Die Bewertung funktioniert wie folgt:
-
Die erste nicht leere Eigenschaft
cq:allowedTemplates
, die beim Aufrufen der mitP
beginnenden Seitenhierarchie gefunden wird, wird mit dem Pfad vonT
abgeglichen. Wenn keiner der Werte übereinstimmt, wirdT
abgelehnt. -
Wenn
T
eine nicht leereallowedPaths
-Eigenschaft hat, aber keiner der Werte mit dem Pfad vonP
übereinstimmt, wirdT
zurückgewiesen. -
Wenn beide oben genannten Eigenschaften entweder leer oder nicht vorhanden sind, wird
T
abgelehnt, es sei denn, es gehört zum selben Programm wieP
.T
gehört genau dann zum selben Programm wieP
, wenn der Name der zweiten Ebene des Pfades vonT
mit dem Namen der zweiten Ebene des Pfades vonP
übereinstimmt. Zum Beispiel gehört die Vorlage/apps/geometrixx/templates/foo
zum selben Programm wie die Seite/content/geometrixx
. -
Wenn
T
eine nicht leereallowedParents
-Eigenschaft hat, aber keiner der Werte mit dem Pfad vonP
übereinstimmt, wirdT
zurückgewiesen. -
Wenn die Vorlage von
P
eine nicht leereallowedChildren
-Eigenschaft hat, aber keiner der Werte mit dem Pfad vonT
übereinstimmt, wirdT
zurückgewiesen. -
In allen anderen Fällen ist
T
zulässig.
Das folgende Diagramm zeigt den Vorlagenauswertungsprozess:
Einschränkende Vorlagen in untergeordneten Seiten limiting-templates-used-in-child-pages
Um zu begrenzen, welche Vorlagen zum Erstellen von untergeordneten Seiten unter einer bestimmten Seite verwendet werden können, verwenden Sie die Eigenschaft cq:allowedTemplates
des Knotens jcr:content
auf der Seite. Damit lässt sich die Liste der Vorlagen angeben, die als untergeordnete Seiten zulässig sein sollen. Jeder Wert in der Liste muss ein absoluter Pfad zu einer Vorlage für eine zulässige untergeordnete Seite sein, zum Beispiel /apps/geometrixx/templates/contentpage
.
Sie können die Eigenschaft cq:allowedTemplates
im Knoten jcr:content
der Vorlage verwenden, damit diese Konfiguration auf alle neu erstellten Seiten angewendet wird, die diese Vorlage nutzen.
Wenn Sie mehrere Einschränkungen hinzufügen möchten, z. B. bezüglich der Vorlagenhierarchie, können Sie die Eigenschaften allowedParents/allowedChildren
der Vorlage verwenden. Sie können dann explizit angeben, dass Seiten, die aus einer Vorlage T erstellt wurden, übergeordnet/untergeordnet von Seiten sein müssen, die aus einer Vorlage T erstellt wurden.
Vorlagen – Inhaltsfragmente templates-content-fragments
Siehe Inhaltsfragmentvorlagen.