Comment modéliser votre contenu model-your-content

Dans cette partie du Parcours de développement AEM Headless, vous pouvez apprendre à modéliser votre structure de contenu. Ensuite, réalisez cette structure pour Adobe Experience Manager (AEM) à l’aide des modèles de fragments de contenu et des fragments de contenu, afin de la réutiliser sur plusieurs canaux.

Un peu d’histoire… story-so-far

Pour commencer, la section En savoir plus sur le développement CMS découplé a décrit la diffusion de contenu en mode découplé et les raisons justifiant son utilisation. Continuez avec la section Prise en main d’AEM découplé qui décrit le découplage AEM dans le contexte de votre propre projet.

Dans le document précédent du parcours découplé AEM, Premiers pas vers votre première expérience d’utilisation d’AEM Headless, vous avez découvert les étapes nécessaires à la mise en œuvre de votre premier projet. Après l’avoir lu, vous devriez :

  • comprendre les points importants de sa planification pour concevoir votre contenu ;
  • comprendre les étapes à suivre pour implémenter le découplage en fonction de vos exigences de niveau d’intégration ;
  • configurer les outils et les configurations AEM nécessaires ;
  • connaître les bonnes pratiques vous permettant de fluidifier votre parcours découplé, d’optimiser la génération du contenu et de garantir une diffusion rapide du contenu.

Cet article s’appuie sur ces principes de base pour que vous compreniez comment préparer votre propre projet AEM découplé.

Objectif objective

  • Audience  : débutant

  • Objectif  : découvrez comment modéliser votre structure de contenu, puis réaliser cette structure à l’aide des modèles de fragment de contenu et des fragments de contenu :

    • Présenter les concepts et la terminologie liés à la modélisation de contenu et de données
    • Apprendre pourquoi la modélisation de contenu est nécessaire pour la diffusion de contenu découplé
    • Découvrir comment réaliser cette structure à l’aide des modèles de fragments de contenu AEM (et créer du contenu avec des fragments de contenu).
    • Découvrir comment modéliser votre contenu ; principes avec des exemples de base.
NOTE
La modélisation des données est un sujet très large, car il est utilisé lors du développement de bases de données relationnelles. Beaucoup de livres et de sources d’informations sont disponibles en ligne.
Les aspects qui présentent un intérêt lors de la modélisation des données à utiliser avec AEM Headless sont uniquement pris en compte.

Modélisation de contenu content-modeling

Le monde extérieur est vaste et malveillant.

Peut-être, mais peut-être pas. Il est certain que le monde est extrêmement complexe. La modélisation des données n’est utilisée que pour fournir une représentation simplifiée d’une très (très) petite portion de celui-ci, en utilisant des données spécifiques pour un objectif spécifique.

NOTE
Comme AEM traite du contenu, la modélisation des données est appelée modélisation de contenu.

Par exemple :

Il y a beaucoup d’écoles, mais elles ont toutes différentes choses en commun :

  • Une localisation
  • Un directeur
  • Beaucoup d’enseignants
  • De nombreux membres du personnel non enseignant
  • Beaucoup d’élèves
  • Beaucoup d’anciens enseignants
  • Beaucoup d’anciens élèves
  • De nombreuses salles de classe
  • Beaucoup (beaucoup) de livres
  • Beaucoup (beaucoup) d’équipements
  • De nombreuses activités extrascolaires
  • et ainsi de suite…

Même pour ce simple exemple, la liste peut sembler infinie. Cependant, si vous souhaitez simplement que votre application effectue une tâche simple, vous devez limiter les informations aux éléments essentiels à cette tâche.

Par exemple, la publicité relative à des événements spéciaux pour toutes les écoles de la région :

  • Le nom de l’école
  • L’emplacement de l’école
  • Le directeur
  • Le type d’événement
  • La date de l’événement
  • Le professeur organisant l’événement

Concepts concepts

Nous appelons Entités ce que vous souhaitez décrire, c’est-à-dire les « objets » au sujet desquels vous voulez stocker des informations.

Les informations que vous voulez stocker à leur sujet sont les attributs (propriétés), tels que le nom et les qualifications pour les enseigantes et enseignants.

Il existe ensuite diverses relations entre les entités. Par exemple, en général, une école n’a qu’un seul directeur, et de nombreux enseignants (et généralement le directeur est également enseignant).

Le processus d’analyse et de définition de ces informations, ainsi que les relations entre elles, est appelé Modélisation de contenu.

Concepts de base basics

Souvent, vous pouvez commencer par élaborer un schéma conceptuel qui décrit les entités et leurs relations. Il s’agit généralement d’un niveau supérieur (conceptuel).

Une fois ce schéma établi de manière stable, vous pouvez traduire les modèles en Schéma logique qui décrit les entités, ainsi que les attributs et les relations. À ce niveau, examinez de près les définitions pour éliminer la duplication et optimiser votre conception.

NOTE
Parfois, ces deux étapes sont fusionnées, souvent en fonction de la complexité de votre scénario.

Par exemple, avez-vous besoin d’entités distinctes pour Head Teacher et Teacher, ou simplement d’un attribut supplémentaire sur le modèle Teacher ?

Assurer l’intégrité des données data-integrity

L’intégrité des données est nécessaire pour garantir la précision et la cohérence de votre contenu tout au long de son cycle de vie. Cela implique de s’assurer que les auteurs de contenu peuvent facilement comprendre où le stocker, les éléments suivants sont donc essentiels :

  • Une structure claire
  • Une structure aussi concise que possible (sans sacrifier la précision)
  • La validation de champs individuels
  • Le cas échéant, limitez le contenu des champs spécifiques au plus important

Suppression de la redondance de données data-redundancy

La redondance des données se produit lorsque les mêmes informations sont stockées deux fois dans la structure de contenu. Vous devez éviter cette situation, car elle peut prêter à confusion lors de la création du contenu et entraîner des erreurs lors de l’interrogation, outre la mauvaise utilisation de l’espace de stockage.

Optimisation et performance optimization-and-performance

En optimisant votre structure, vous pouvez améliorer les performances, tant pour la création de contenu que pour l’interrogation.

Tout est une question d’équilibre, mais la création d’une structure trop complexe ou possédant un nombre excessif de niveaux, peut avoir pour conséquences :

  • De la confusion pour les auteurs qui génèrent le contenu.

  • Un impact considérable sur les performances lorsque la requête doit accéder à plusieurs fragments de contenu imbriqués (référencés) pour récupérer le contenu nécessaire.

Modélisation de contenu pour le découplage AEM content-modeling-for-aem-headless

La modélisation des données est un ensemble de techniques établies, souvent utilisées lors de bases de données de relations développées. Que signifie la modélisation de contenu pour le découplage AEM ?

Pourquoi ? why

Pour que votre application puisse demander et recevoir le contenu requis d’AEM de manière cohérente et efficace, ce contenu doit être structuré.

Votre application connaît donc à l’avance la forme de réponse et, donc, comment la traiter. Cette approche est plus simple à traiter que de recevoir du contenu sous forme libre, qui doit être analysé pour déterminer ce qu’il contient et, donc, comment l’utiliser.

Comment ? how

AEM utilise des fragments de contenu pour fournir les structures nécessaires pour une diffusion en mode découplé de votre contenu vers vos applications.

La structure de votre modèle de contenu possède les caractéristiques suivantes :

  • Elle est réalisée par la définition de votre modèle de fragment de contenu,
  • Elle est utilisée comme base des fragments de contenu utilisés pour la génération de votre contenu.
NOTE
Les modèles de fragment de contenu sont également utilisés comme base des schémas GraphQL d’AEM utilisés pour récupérer votre contenu – en savoir plus à ce sujet lors d’une session ultérieure.

Les demandes de contenu sont effectuées à l’aide de l’API AEM GraphQL, une mise en œuvre personnalisée de l’API GraphQL standard. L’API AEM GraphQL permet d’effectuer des requêtes (complexes) sur vos fragments de contenu ; chaque requête étant conforme à un type de modèle spécifique.

Le contenu renvoyé peut alors être utilisé par vos applications.

Création de la structure à l’aide de modèles de fragment de contenu create-structure-content-fragment-models

Les modèles de fragment de contenu offrent divers mécanismes qui vous permettent de définir la structure de votre contenu.

Un modèle de fragment de contenu décrit une entité.

NOTE
Activez la fonctionnalité Fragment de contenu dans l’explorateur de configurations afin de pouvoir créer des modèles.
TIP
Le modèle doit être nommé de sorte que l’auteur du contenu sache quel modèle sélectionner lors de la création d’un fragment de contenu.

Dans un modèle :

  1. Les types de données vous permettent de définir les attributs individuels.
    Par exemple, définissez le champ portant le nom d’un enseignant comme Texte et ses années de service comme Nombre.
  2. Les types de données Référence de contenu et Référence du fragment permettent de créer des relations avec d’autres contenus dans AEM.
  3. Le type de données Référence de fragment vous permet de réaliser plusieurs niveaux de structure en imbriquant vos fragments de contenu (en fonction du type de modèle). Ceci est essentiel pour la modélisation de contenu.

Par exemple :
Modélisation de contenu avec des fragments de contenu

Types de données data-types

AEM fournit les types de données suivants pour que vous puissiez modéliser votre contenu :

  • Texte d’une seule ligne
  • Texte de plusieurs lignes
  • Nombre
  • Booléen
  • Date et heure
  • Énumération
  • Balises
  • Référence de contenu
  • Référence du fragment
  • Objet JSON

Références et contenu imbriqué references-nested-content

Deux types de données fournissent des références au contenu en dehors d’un fragment spécifique :

  • Référence de contenu
    Il s’agit d’une référence simple à tout autre contenu de n’importe quel type.
    Par exemple, vous pouvez référencer une image à un emplacement spécifié.

  • Référence du fragment
    Cette section fournit des références à d’autres fragments de contenu.
    Ce type de référence est utilisé pour créer du contenu imbriqué, présentant les relations nécessaires au modèle de votre contenu.
    Le type de données peut être configuré pour permettre aux auteurs de fragments de procéder aux opérations suivantes :

    • Modifier directement le fragment référencé.
    • Créer un fragment de contenu, en fonction du modèle approprié.

Création de modèles de fragment de contenu creating-content-fragment-models

Au début, vous devez activer les modèles de fragment de contenu pour votre site. Cette activation s’effectue dans l’explorateur de configurations, dans Outils > Général > Explorateur de configurations. Vous pouvez choisir de configurer l’entrée globale ou de créer une configuration. Par exemple :

Définir la configuration

NOTE
Voir Ressources supplémentaires – Fragments de contenu dans l’explorateur de configurations

Ensuite, les modèles de fragments de contenu peuvent être créés et la structure définie. Ces actions peuvent être réalisées dans Outils > Ressources > Modèles de fragment de contenu. Par exemple :

Modèle de fragment de contenu

NOTE
Voir Ressources supplémentaires – Modèles de fragment de contenu.

Utilisation du modèle pour créer du contenu avec des fragments de contenu use-content-to-author-content

Les fragments de contenu sont toujours basés sur un modèle de fragment de contenu. Le modèle fournit la structure, le fragment contient le contenu.

Sélection du modèle approprié select-model

La première étape pour créer réellement votre contenu consiste à créer un fragment de contenu. Pour ce faire, utilisez Créer > Fragment de contenu dans le dossier requis dans Ressources > Fichiers. L’assistant vous guide tout au long des étapes.

Un fragment de contenu est basé sur un modèle de fragment de contenu spécifique que vous sélectionnez comme première étape du processus de création.

Création et modification de contenu structuré create-edit-structured-content

Une fois votre fragment créé, vous pouvez l’ouvrir dans l’éditeur de fragment de contenu. Vous pouvez y effectuer les opérations suivantes :

  • Modifier votre contenu en mode normal ou plein écran.
  • Mettre en forme le contenu sous forme de texte intégral, texte brut ou Markdown.
  • Créer et gérer des variations de votre contenu.
  • Associer le contenu.
  • Modifier les métadonnées.
  • Afficher l’arborescence.
  • Prévisualiser la représentation JSON.

Création de fragments de contenu creating-content-fragments

Après avoir sélectionné le modèle approprié, un fragment de contenu est ouvert pour modification dans l’éditeur de fragment de contenu :

Éditeur de fragment de contenu

NOTE
Voir Ressources supplémentaires – Utilisation de fragments de contenu.

Prise en main de quelques exemples getting-started-examples

Pour obtenir une structure de base en tant qu’exemple, voir la section Exemple de structure de fragment de contenu.

Et après ? whats-next

Maintenant que vous avez appris à modéliser votre structure et à créer du contenu en fonction de cela, l’étape suivante consiste à découvrir comment utiliser les requêtes GraphQL pour accéder à votre contenu de fragments de contenu et le récupérer. Vous pourrez ainsi bénéficier d’une présentation du langage GraphQL, puis accéder à un certain nombre d’exemples de requêtes pour voir comment tout cela fonctionne en pratique.

Ressources supplémentaires additional-resources

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