Komponenten für Inhaltsfragmente components-for-content-fragments

Komponenten für die Fragmentbearbeitung components-for-fragment-authoring

CAUTION
Es wird nicht empfohlen, die im Fragmenteditor tatsächlich verwendeten Komponenten zu erweitern oder zu ändern, da sie sich noch ändern können.

Siehe Client-seitige API für die Inhaltsfragmentverwaltung.

Komponenten für die Seitenbearbeitung components-for-page-authoring

CAUTION
Derzeit wird die Kernkomponente für Inhaltsfragmente dafür empfohlen. Weitere Informationen finden Sie unter Entwickeln von Kernkomponenten.
In diesem Abschnitt wird die ursprüngliche Komponente beschrieben, die zur Verwendung mit Inhaltsfragmenten bereitgestellt wird (Inhaltsfragment in der Gruppe Allgemein).
NOTE
Weitere Informationen finden Sie unter Inhaltsfragmente – Konfigurieren von Komponenten für das Rendering.

Inhaltsfragmente für Adobe Experience Manager (AEM) werden als seitenunabhängige Assets erstellt und verwaltet. Sie ermöglichen es Ihnen, kanalneutrale Inhalte zusammen mit (möglicherweise kanalspezifischen) Varianten zu erstellen. Sie können diese Fragmente und ihre Varianten bei der Erstellung Ihrer Inhaltsseiten verwenden. Sie können auch ein vorhandenes Inhaltsfragment-Asset verwenden, indem Sie es vom Asset-Browser auf die Seite ziehen (wie bei anderen Asset-basierten Komponenten, z. B. der Foundation-Bildkomponente). Die vorkonfigurierte Inhaltsfragmentkomponente zeigt nur ein Element des referenzierten Inhaltsfragments an. Unter Verwendung des Komponentendialogfelds können Sie das Element, die Variante und den Bereich der Fragmentabsätze definieren, die auf der Seite angezeigt werden sollen.

NOTE
Diese Inhaltsfragment-Komponente wurde in AEM 6.2 als erweiterte Version der nicht mehr unterstützten Artikelkomponente eingeführt.
NOTE
Inhaltsfragmente werden in der klassischen Benutzeroberfläche nicht unterstützt.

Definition definition

Die Inhaltsfragment komponente wird verwendet, um einen Verweis auf ein Inhaltsfragment-Asset zu halten (effektiv erweiterte Text-Assets). Der Ressourcentyp für das Inhaltsfragment lautet:

dam/cfm/components/contentfragment/contentfragment

Die Referenz ist in der Eigenschaft definiert:

fileReference

Nur der Editor der Touch-optimierten Benutzeroberfläche unterstützt Inhaltsfragmentkomponenten, einschließlich der Client-Bibliothek, vollständig:

cq.authoring.editor.plugin.cfm

Diese Bibliothek fügt dem Editor spezielle Funktionen für Inhaltsfragmente hinzu. So werden beispielsweise das Hinzufügen und Konfigurieren von Inhaltsfragmenten auf der Seite, die Suche nach Inhaltsfragment-Assets im Asset-Browser und die Suche nach zugehörigen Inhalten im seitlichen Bedienfeld unterstützt.

Übergangsinhalte in-between-content

Mit der Inhaltsfragmentkomponente können Sie zusätzliche Komponenten zwischen den verschiedenen Absätzen des angezeigten Elements einfügen. Grundsätzlich besteht das angezeigte Element aus verschiedenen Absätzen (jeder Absatz ist durch einen Wagenrücklauf gekennzeichnet). Zwischen diesen Absätzen können Sie Inhalte mithilfe anderer Komponenten einfügen.

Aus technischer Sicht wird jeder Absatz des angezeigten Elements in seinem eigenen Absatzsystem ausgeführt, und jede Komponente, die Sie zwischen den Absätzen einfügen, wird (im Verborgenen) im Absatzsystem eingefügt.

Mit anderen Worten: Wenn die Instanz der Inhaltsfragmentkomponente aus drei Absätzen besteht, hat die Komponente drei verschiedene Absatzsysteme im Repository. Der gesamte Zwischeninhalt, der dem Inhaltsfragment hinzugefügt wird, befindet sich tatsächlich innerhalb dieser Absatzsysteme.

Im Repository wird der Zwischeninhalt relativ zu seiner Position innerhalb der gesamten Absatzstruktur gespeichert, d. h. er wird nicht an den tatsächlichen Absatzinhalt angehängt.

Um dies zu veranschaulichen, beachten Sie, dass Sie über Folgendes verfügen:

  • Eine Instanz eines Inhaltsfragments, das aus drei Absätzen besteht

  • Und dass einige Inhalte bereits nach dem zweiten Absatz eingefügt wurden

    • Dies bedeutet, dass der Inhalt im zweiten Absatzsystem gespeichert wird.

Grundsätzlich, wenn sich die Absatzstruktur dieser Instanz ändert (indem die Variante, das Element oder der Bereich der angezeigten Absätze geändert wird), kann sich dies auf den Übergangsinhalt auswirken, der beim Inhalt des Inhaltsfragments angezeigt wird:

  • Wird bearbeitet und vor dem zweiten Absatz wird ein weiterer Absatz eingefügt:

    • Der Zwischeninhalt wird nach dem neu erstellten Absatz angezeigt (das zweite Absatzsystem enthält nun den neu erstellten Absatz).
  • Wird bearbeitet und der zweite Absatz wird entfernt:

    • Der Zwischeninhalt wird nach dem Absatz angezeigt, der zuvor der dritte Absatz war (das zweite Absatzsystem enthält jetzt den vorherigen dritten Absatz).
  • Ist so konfiguriert, dass nur der erste Absatz angezeigt wird:

    • Der Zwischeninhalt wird nicht angezeigt (das zweite Absatzsystem wird aufgrund der neuen Konfiguration nicht mehr gerendert).

Anpassen der Inhaltsfragmentkomponente customizing-the-content-fragment-component

Um die vordefinierte Inhaltsfragmentkomponente als Blueprint für die Erweiterung zu verwenden, müssen Sie folgenden Vertrag einhalten:

  • Verwenden Sie das HTL-Wiedergabeskript und das zugehörige POJO erneut, um zu sehen, wie die Funktion für Zwischeninhalte implementiert wird.

  • Verwenden Sie den Inhaltsfragmentknoten erneut: cq:editConfig

    • Die Listener afterinsert/ afteredit/ afterdelete werden zum Auslösen von JS-Ereignissen verwendet. Diese Ereignisse werden in der Client-Bibliothek cq.authoring.editor.plugin.cfm behandelt, um den zugehörigen Inhalt im Seitenbereich anzuzeigen.
    • Die cq:dropTargets sind so konfiguriert, dass das Ziehen von Inhaltsfragment-Assets unterstützt wird.
    • cq:inplaceEditing wurde konfiguriert, um das Erstellen eines Inhaltsfragments im Seiteneditor zu unterstützen. Der Editor für die Bearbeitung im Kontext für Fragmente ist in der Client-Bibliothek cq.authoring.editor.plugin.cfm definiert und ermöglicht eine schnelle Verknüpfung zum Öffnen des aktuellen Elements/der aktuellen Variante im Fragmenteditor.

Neuschreibung eines Assets vor dem Rendern asset-rewriting-before-rendering

Die Inhaltsfragmentverwaltung verwendet einen internen Renderprozess, um die endgültige HTML-Ausgabe für eine Seite zu generieren. Dies wird intern von der Inhaltsfragmentkomponente, aber auch vom Hintergrundprozess verwendet, der referenzierte Fragmente auf referenzierenden Seiten aktualisiert.

Intern wird der Sling Rewriter für dieses Rendering verwendet. Die entsprechende Konfiguration kann unter /libs/dam/config/rewriter/cfm gefunden und bei Bedarf angepasst werden. Weitere Informationen finden Sie unter Apache Sling Rewriter.

CAUTION
Wenn Sie die Konfiguration des Rewriters anpassen/überlagern:
  • /libs/dam/config/rewriter/cfm
dann muss der serializerType aktualisiert werden auf:
  • serializerType="html5-serializer"

Die Standardkonfiguration verwendet folgende Transformatoren:

  • transformer-cfm-payloadfilter – nur für das Abrufen des body-Teils (<body>...</body>) der HTML des Fragments

  • transformer-cfm-parfilter – filtert unerwünschte Absätze heraus, wenn ein Absatzbereich angegeben wurde (wie bei der Inhaltsfragmentkomponente möglich)

  • transformer-cfm-assetprocessor – wird intern zum Abrufen einer Liste der Assets verwendet, die im Fragment eingebettet sind

Der Rendervorgang wird über com.adobe.cq.dam.cfm.content.FragmentRenderService verfügbar gemacht und kann bei Bedarf (zum Beispiel) von benutzerdefinierten Komponenten genutzt werden.

recommendation-more-help
19ffd973-7af2-44d0-84b5-d547b0dffee2