Markdown
Le Markdown est couramment utilisé pour créer des contenus à forte teneur en texte, tels que des articles de blog et de la documentation. Astro inclut une prise en charge intégrée des fichiers Markdown standard qui peuvent également inclure un frontmatter YAML pour définir des propriétés personnalisées telles qu’un titre, une description et des balises.
Dans Astro, vous pouvez créer du contenu en utilisant GitHub Flavored Markdown, puis l’afficher dans des composants .astro
. Cela combine un format d’écriture familier conçu pour le contenu avec la flexibilité de la syntaxe et de l’architecture des composants d’Astro.
Pour des fonctionnalités supplémentaires, telles que l’inclusion de composants et d’expressions JSX dans Markdown, ajoutez l’intégration @astrojs/mdx
pour écrire votre contenu Markdown en utilisant MDX.
Organiser les fichiers Markdown
Titre de la section Organiser les fichiers MarkdownVos fichiers Markdown locaux peuvent être conservés n’importe où dans votre répertoire src/
. Les fichiers Markdown situés dans src/pages/
généreront automatiquement des pages Markdown sur votre site.
Votre contenu Markdown et vos propriétés frontmatter peuvent être utilisés dans les composants via des importations de fichiers locaux ou lorsqu’ils sont interrogés et rendus à partir de données récupérées par une fonction d’assistance de collections de contenu.
Importations de fichiers vs requêtes de collections de contenu
Titre de la section Importations de fichiers vs requêtes de collections de contenuVos fichiers Markdown locaux peuvent être importés dans les composants .astro
en utilisant une instruction import
pour un seul fichier et import.meta.glob()
de Vite pour interroger plusieurs fichiers à la fois. Les données exportées à partir de ces fichiers Markdown peuvent ensuite être utilisées dans le composant .astro
.
Si vous avez des groupes de fichiers Markdown apparentés, envisagez de les définir comme des collections. Cela présente plusieurs avantages, notamment la possibilité de stocker les fichiers Markdown n’importe où sur votre système de fichiers ou à distance.
Les collections utilisent des API optimisées et spécifiques au contenu pour interroger et restituer votre contenu Markdown au lieu d’importer des fichiers. Les collections sont destinées aux ensembles de données qui partagent la même structure, tels que les articles de blog ou les pages de produits. Lorsque vous définissez cette forme dans un schéma, vous bénéficiez en outre de la validation, de la sécurité des types et de l’Intellisense dans votre éditeur.
Expressions dynamiques de type JSX
Titre de la section Expressions dynamiques de type JSXAprès avoir importé ou analysé des fichiers Markdown, vous pouvez écrire des modèles HTML dynamiques dans vos composants .astro
qui incluent les données du frontmatter et le contenu du corps du texte.
Propriétés disponibles
Titre de la section Propriétés disponiblesMarkdown à partir des requêtes de collections de contenu
Titre de la section Markdown à partir des requêtes de collections de contenuLorsque vous récupérez des données de vos collections avec les fonctions d’aide getCollection()
ou getEntry()
, les propriétés du frontmatter de votre Markdown sont disponibles dans un objet data
(par exemple post.data.title
). De plus, body
contient le contenu brut, non compilé, sous forme de chaîne de caractères.
La fonction render()
renvoie le contenu du corps de votre Markdown, une liste de titres générée, ainsi qu’un objet frontmatter modifié après l’application de tout plugin Remark ou Rehype.
Importation de Markdown
Titre de la section Importation de MarkdownLes propriétés exportées suivantes sont disponibles dans votre composant .astro
lors de l’importation de Markdown en utilisant import
ou import.meta.glob()
:
file
- Le chemin absolu du fichier (par exemple/home/user/projects/.../file.md
).url
- L’URL de la page (par exemple/fr/guides/markdown-content
).frontmatter
- Contient toutes les données spécifiées dans le frontmatter YAML du fichier.<Content />
- Un composant qui renvoie le contenu complet et affiché du fichier.RawContent()
- Une fonction qui renvoie le document Markdown brut sous forme de chaîne de caractères.compiledContent()
- Une fonction asynchrone qui retourne le document Markdown compilé en une chaîne HTML.getHeadings()
- Une fonction asynchrone qui retourne un tableau de tous les titres (<h1>
à<h6>
) dans le fichier avec le type :{ depth: number ; slug: string ; text: string }[]
. Leslug
de chaque titre correspond à l’identifiant généré pour un titre donné et peut être utilisé pour les liens d’ancrage.
Un exemple de billet de blog en Markdown peut passer l’objet Astro.props
suivant :
Le composant <Content />
Titre de la section Le composant <Content />Le composant <Content />
est disponible en important Content
à partir d’un fichier Markdown. Ce composant renvoie le contenu complet du fichier, affiché en HTML. Vous pouvez optionnellement renommer Content
en n’importe quel nom de composant que vous préférez.
Vous pouvez également rendre le contenu HTML d’une entrée de collection Markdown en affichant un composant <Content />
.
ID des titres
Titre de la section ID des titresEn écrivant des titres en Markdown, vous obtiendrez automatiquement des liens d’ancrage qui vous permettront d’accéder directement à certaines sections de votre page.
Astro génère des id
s d’en-tête basés sur github-slugger
. Vous pouvez trouver plus d’exemples dans la documentation de github-slugger.
ID des titres et plugins
Titre de la section ID des titres et pluginsAstro injecte un attribut id
dans tous les éléments d’en-tête (<h1>
à <h6>
) dans les fichiers Markdown et MDX. Vous pouvez récupérer ces données à partir de l’utilitaire getHeadings()
disponible en tant que propriété exportée Markdown à partir d’un fichier importé, ou à partir de la fonction render()
lorsque vous utilisez du Markdown renvoyé à partir d’une requête de collections de contenu.
Vous pouvez personnaliser ces ID en ajoutant un plugin rehype qui injecte les attributs id
(par exemple rehype-slug
). Vos ID personnalisés, au lieu des valeurs par défaut d’Astro, seront reflétés dans la sortie HTML et les éléments retournés par getHeadings()
.
Par défaut, Astro injecte les attributs id
après l’exécution de vos plugins rehype. Si l’un de vos plugins rehype personnalisés a besoin d’accéder aux ID injectés par Astro, vous pouvez importer et utiliser directement le plugin rehypeHeadingIds
d’Astro. Assurez-vous d’ajouter rehypeHeadingIds
avant tous les plugins qui en dépendent :
Plugins Markdown
Titre de la section Plugins MarkdownLa prise en charge de Markdown dans Astro est assurée par remark, un puissant outil d’analyse et de traitement doté d’un écosystème actif. D’autres analyseurs Markdown comme Pandoc et markdown-it ne sont pas supportés actuellement.
Astro applique par défaut les plugins GitHub-flavored Markdown et SmartyPants. Cela permet de générer des liens cliquables à partir du texte et de formater les citations et les tirets cadratins.
Vous pouvez personnaliser la façon dont remark analyse votre Markdown dans astro.config.mjs
. Voir la liste complète des options de configuration Markdown.
Ajouter des plugins remark et rehype
Titre de la section Ajouter des plugins remark et rehypeAstro prend en charge l’ajout de plugins tiers remark et rehype pour Markdown. Ces plugins vous permettent d’étendre votre Markdown avec de nouvelles fonctionnalités, comme générer automatiquement une table des matières, appliquer des étiquettes accessibles aux émojis et styliser votre Markdown.
Nous vous encourageons à consulter awesome-remark et awesome-rehype parmi les plugins populaires ! Consultez le fichier README de chaque plugin pour obtenir des instructions d’installation spécifiques.
Cet exemple applique remark-toc
et rehype-accessible-emojis
aux fichiers Markdown :
Personnaliser un plugin
Titre de la section Personnaliser un pluginPour personnaliser un plugin, il faut lui ajouter un objet d’options dans un tableau imbriqué.
L’exemple ci-dessous ajoute l’option heading
au plugin remarkToc
pour modifier l’emplacement de la table des matières, et l’option behavior
au plugin rehype-autolink-headings
afin d’ajouter la balise d’ancrage après le texte du titre.
Modification programmatique du frontmatter
Titre de la section Modification programmatique du frontmatterVous pouvez ajouter des propriétés au frontmatter de tous vos fichiers Markdown et MDX en utilisant un plugin remark ou rehype.
-
Ajoutez une propriété
customProperty
à l’objetdata.astro.frontmatter
présent dans l’argumentfile
de votre plugin :Ajouté à la version :astro@2.0.0
data.astro.frontmatter
contient toutes les propriétés d’un document Markdown ou MDX donné. Cela vous permet de modifier les propriétés existantes du frontmatter, ou de calculer de nouvelles propriétés à partir de ce frontmatter existant. -
Appliquez ce plugin à votre configuration d’intégration
markdown
oumdx
:ou
Maintenant, chaque fichier Markdown ou MDX aura une propriété customProperty
dans son frontmatter, ce qui la rendra disponible lors de l’importation de votre Markdown et à partir de la propriété Astro.props.frontmatter
dans vos mises en page.
Étendre la configuration Markdown à partir de MDX
Titre de la section Étendre la configuration Markdown à partir de MDXL’intégration MDX d’Astro étend par défaut la configuration Markdown existante de votre projet. Pour remplacer des options individuelles, vous pouvez spécifier leur équivalent dans votre configuration MDX.
L’exemple suivant désactive l’option GitHub-Flavored Markdown et applique un ensemble différent de plugins Remark pour les fichiers MDX :
Pour éviter d’étendre votre configuration Markdown depuis MDX, mettez l’option extendMarkdownConfig
(activée par défaut) sur false
:
Pages Markdown individuelles
Titre de la section Pages Markdown individuellesLes collections de contenu et l’importation de Markdown dans les composants .astro
offrent davantage de fonctionnalités pour le rendu de votre Markdown et constituent le moyen recommandé pour gérer la plupart de votre contenu. Cependant, il peut arriver que vous souhaitiez simplement ajouter un fichier à src/pages/
et avoir une page simple créée automatiquement pour vous.
Astro traite tout fichier supporté dans le répertoire /src/pages/
comme une page, y compris .md
et d’autres types de fichiers Markdown.
Placer un fichier dans ce répertoire, ou n’importe quel sous-répertoire, construira automatiquement une route de page en utilisant le nom de chemin du fichier et affichera le contenu Markdown affiché en HTML. Astro ajoutera automatiquement une balise <meta charset="utf-8">
à votre page pour permettre une création plus facile de contenu non ASCII.
Propriété layout
du frontmatter
Titre de la section Propriété layout du frontmatterPour aider avec les fonctionnalités limitées des pages Markdown individuelles, Astro fournit une propriété de frontmatter spéciale nommée layout
qui est un chemin relatif vers un composant Astro de mise en page Markdown. layout
n’est pas une propriété spéciale lors de l’utilisation de collections de contenu pour interroger et restituer votre contenu Markdown, et il n’est pas garanti qu’elle soit prise en charge en dehors de son cas d’utilisation prévu.
Si votre fichier Markdown est situé dans src/pages/
, créez un composant de mise en page et ajoutez-le dans cette propriété de mise en page pour fournir une enveloppe de page autour de votre contenu Markdown.
Ce composant de mise en page est un composant Astro normal avec des propriétés spécifiques automatiquement disponibles à travers Astro.props
pour votre modèle Astro. Par exemple, vous pouvez accéder aux propriétés du frontmatter de votre fichier Markdown via Astro.props.frontmatter
:
Lorsque vous utilisez la propriété frontmatter layout
, vous devez inclure la balise <meta charset="utf-8">
dans votre mise en page car Astro ne l’ajoutera plus automatiquement. Vous pouvez désormais également styliser votre Markdown dans votre composant de mise en page.
Récupérer du Markdown à distance
Titre de la section Récupérer du Markdown à distanceAstro n’inclut pas de support intégré pour Markdown à distance en dehors des collections de contenu.
Pour récupérer directement du Markdown distant et le rendre au format HTML, vous devrez installer et configurer votre propre interpréteur de Markdown à partir de NPM. Celui-ci n’héritera pas des paramètres Markdown intégrés d’Astro que vous avez configurés.
Assurez-vous de bien comprendre ces limitations avant d’implémenter ceci dans votre projet, et envisagez de récupérer votre Markdown distant en utilisant un chargeur de collections de contenu à la place.
Learn