Dropdown et Liste des sujets Starlight ensemble
Cette traduction a été générée par une IA générative à l'aide de la traduction continue Action. →
En utilisant le plugin
Starlight Sidebar Topics avec le composant
Starlight Sidebar Topics Dropdown, vous pouvez créer un site web qui affiche une liste de sujets sur le bureau et un menu déroulant sur mobile.
Vous devez disposer d’un site web Starlight existant.
Tout d’abord, installez le plugin starlight-sidebar-topics ainsi que le composant starlight-sidebar-topics-dropdown :
npm install starlight-sidebar-topics starlight-sidebar-topics-dropdownpnpm add starlight-sidebar-topics starlight-sidebar-topics-dropdownyarn add starlight-sidebar-topics starlight-sidebar-topics-dropdownEnsuite, suivez les guides d’installation de Starlight Sidebar Topics et de Starlight Sidebar Topics Dropdown.
Dans le guide d’installation du composant déroulant, vous avez créé un composant de barre latérale qui ne rend que le menu déroulant. Désormais, vous devez modifier ce composant pour qu’il rende également la barre latérale par défaut si l’utilisateur est sur un bureau.
---import Default from '@astrojs/starlight/components/Sidebar.astro';import Topics from 'starlight-sidebar-topics/components/Sidebar.astro';import TopicsDropdown from 'starlight-sidebar-topics-dropdown/TopicsDropdown.astro';---
<div class="topics"> <Topics/></div><div class="topics-dropdown"> <TopicsDropdown/></div><Default><slot /></Default>
<style> /* Hide topics by default and show them on medium screens and larger */ .topics { display: none; }
@media (min-width: 800px) { .topics { display: block; } }
/* Show topics dropdown on small screens and hide it on medium screens and larger */ .topics-dropdown { display: block; }
@media (min-width: 800px) { .topics-dropdown { display: none; } }</style>Si vous suivez ces étapes, votre barre latérale ressemblera à ceci :

Vous pouvez trouver le code source complet de ce guide dans cet exemple StackBlitz.
Vous pourriez également faire l’inverse (liste sur mobile, menu déroulant sur le bureau) en intervertissant les propriétés display: block et display: none dans le CSS.
De plus, vous pourriez également créer votre propre composant d’affichage, qui utilise les données de route du plugin Starlight Sidebar Topics et rend les sujets de manière personnalisée. Cela est un peu plus avancé, mais vous pouvez trouver plus d’informations à ce sujet dans la documentation “Custom Topics List”.