Installation
Docusaurus est essentiellement un ensemble de paquets de npm.
Utilisez la Procédure accélérée pour comprendre Docusaurus 5 minutes ⏱ !
Utilisez docusaurus.new pour tester immédiatement Docusaurus dans votre navigateur !
Pré-requis
- Node.js version 16.14 ou supérieure (qui peut être vérifiée en exécutant
node -v
). Vous pouvez utiliser nvm pour gérer plusieurs versions de Node sur une seule machine installée.- Lors de l'installation de Node.js, il est recommandé de cocher toutes les cases liées aux dépendances.
Structurer un site web d'un projet
La façon la plus simple d'installer Docusaurus est d'utiliser l'outil en ligne de commande qui vous aide à créer un squelette de site web Docusaurus. Vous pouvez exécuter cette commande n'importe où dans un nouveau dépôt vide ou dans un dépôt existant, elle créera un nouveau répertoire contenant les fichiers de structure.
npx create-docusaurus@latest my-website classic
Nous recommandons le template classic
pour que vous puissiez commencer rapidement et il contient des fonctionnalités disponibles dans Docusaurus 1. Le template classic
contient @docusaurus/preset-classic
qui inclut une documentation standard, un blog, des pages personnalisées et un framework CSS (avec support du mode sombre). Vous pouvez être opérationnel très rapidement avec le template classic et personnaliser les choses plus tard, lorsque vous serez plus familier avec Docusaurus.
Vous pouvez également utiliser la variante TypeScript du template en passant l'option --typescript
. Consultez Support de TypeScript pour plus d'informations.
npx create-docusaurus@latest my-website classic --typescript
Si vous configurez un nouveau site web Docusaurus pour un projet open source Facebook, utilisez le template facebook
à la place, qui est fourni avec quelques valeurs par défaut utiles propres à Facebook :
npx create-docusaurus@latest my-website facebook
Commandes d'installation alternatives
Vous pouvez également initialiser un nouveau projet en utilisant votre gestionnaire de projet préféré :
- npm
- Yarn
- pnpm
npm init docusaurus
yarn create docusaurus
pnpm create docusaurus
Exécutez npx create-docusaurus@latest --help
, ou consulter ses docs de l'API pour plus informations à propos des options disponibles.
Structure du projet
En supposant que vous avez choisi le template classic et nommé votre site my-website
, vous verrez les fichiers suivants générés dans un nouveau répertoire my-website/
:
my-website
├── blog
│ ├── 2019-05-28-hola.md
│ ├── 2019-05-29-hello-world.md
│ └── 2020-05-30-welcome.md
├── docs
│ ├── doc1.md
│ ├── doc2.md
│ ├── doc3.md
│ └── mdx.md
├── src
│ ├── css
│ │ └── custom.css
│ └── pages
│ ├── styles.module.css
│ └── index.js
├── static
│ └── img
├── docusaurus.config.js
├── package.json
├── README.md
├── sidebars.js
└── yarn.lock
Récapitulatif de la structure du projet
/blog/
- Contient les fichiers Markdown du blog. Vous pouvez supprimer le répertoire si vous avez désactivé le plugin du blog, ou vous pouvez changer son nom après avoir défini l'optionpath
. Vous trouverez plus de détails dans le guide du blog/docs/
- Contient les fichiers Markdown pour la documentation. Personnalisez l'ordre de la barre latérale des docs danssidebars.js
. Vous pouvez supprimer le répertoire si vous avez désactivé le plugin des docs, ou vous pouvez changer son nom après avoir défini l'optionpath
. Vous trouverez plus de détails dans le guide des docs/src/
- Fichiers de non-documentation comme les pages ou les composants React personnalisés. Vous n'êtes pas obligé de placer vos fichiers de non-documentation ici, mais les placer dans un répertoire centralisé permet de les spécifier plus facilement au cas où vous auriez besoin de faire une sorte de vérification/traitement/src/pages
- Tous les fichiers JSX/TSX/MDX de ce répertoire seront convertis en page de site. Vous trouverez plus de détails dans le guide des pages
/static/
- Répertoire statique. Tout contenu à l'intérieur sera copié à la racine du répertoire final dubuild
/docusaurus.config.js
- Un fichier de configuration contenant la configuration du site. Ceci est l'équivalent desiteConfig.js
dans Docusaurus v1/package.json
- Un site Web Docusaurus est une application React. Vous pouvez y installer et utiliser tous les paquets npm que vous souhaitez/sidebars.js
- Utilisé par la documentation pour spécifier l'ordre des documents dans la barre latérale
Monorepos
Si vous utilisez Docusaurus pour la documentation d'un projet existant, un monorepo peut être la solution pour vous. Les monorepos vous permet de partager des dépendances entre des projets similaires. Par exemple, votre site Web peut utiliser vos paquets locaux pour mettre en valeur les dernières fonctionnalités au lieu de dépendre d'une version publiée ; vos contributeurs peuvent également mettre à jour facilement les documentations au fur et à mesure qu'elles implémentent des fonctionnalités. Un exemple de structure de dossier monorepo est ci-dessous :
my-monorepo
├── package-a # Un autre paquet, votre projet actuel
│ ├── src
│ └── package.json # Les dépendances du paquet A
├── website # racine de Docusaurus
│ ├── docs
│ ├── src
│ └── package.json # Les dépendances de Docusaurus
├── package.json # dépendances partagées du monorepo
Dans ce cas, vous devriez exécuter npx create-docusaurus
dans le dossier ./my-monorepo
.
Si vous utilisez un hébergeur comme Netlify ou Vercel, vous devrez changer le répertoire de base
du site à l'endroit où se trouve votre racine Docusaurus. Dans ce cas, ce serait ./website
. Pour en savoir plus sur la configuration des commandes ignorées, consultez la documentation sur le déploiement.
En savoir plus sur les monorepos dans la documentation Yarn (Yarn n'est pas le seul moyen de mettre en place un monorepo, mais c'est une solution commune), ou vérifiez Docusaurus et Jest pour quelques exemples du monde réel.
Exécution du serveur de développement
Pour prévisualiser vos modifications au fur et à mesure que vous modifiez les fichiers, vous pouvez lancer un serveur de développement local qui servira votre site Web et reflétera les dernières modifications.
- npm
- Yarn
- pnpm
cd my-website
npm run start
cd my-website
yarn run start
cd my-website
pnpm run start
Par défaut, une fenêtre du navigateur s'ouvrira sur http://localhost:3000
.
Félicitations ! Vous venez de créer votre premier site Docusaurus ! Naviguez sur le site pour voir ce qui est disponible.
Construction
Docusaurus est un générateur de site web statique moderne donc nous avons besoin de construire le site web dans un répertoire de contenu statique et de le mettre sur un serveur web pour qu'il puisse être consulté. Pour construire le site web :
- npm
- Yarn
- pnpm
npm run build
yarn build
pnpm run build
et le contenu sera généré dans le répertoire /build
, qui peut être copié dans n'importe quel service d'hébergement de fichiers statique comme GitHub pages, Vercel ou Netlify. Consultez la documentation sur le déploiement pour plus de détails.
Mise à jour de votre version Docusaurus
Il y a de nombreuses façons de mettre à jour votre version de Docusaurus. Une façon garantie est de changer manuellement le numéro de version dans package.json
à la version désirée. Notez que tous les paquets nommés @docusaurus/
doivent utiliser la même version.
Vous parcourez la documentation d'une version obsolète. L'extrait ci-dessous montre comment mettre à jour vers la dernière version.
{
"dependencies": {
"@docusaurus/core": "3.5.2",
"@docusaurus/preset-classic": "3.5.2",
// ...
}
}
Ensuite, dans le répertoire contenant le fichier package.json
, exécutez la commande d'installation de votre gestionnaire de paquets :
- npm
- Yarn
- pnpm
npm install
yarn install
pnpm install
Pour vérifier que la mise à jour a été effectuée avec succès, exécutez :
npx docusaurus --version
Vous devriez voir la version correcte en résultat.
Alternativement, si vous utilisez Yarn, vous pouvez faire :
yarn upgrade @docusaurus/core@latest @docusaurus/preset-classic@latest
Utilisez de nouvelles fonctionnalités inédites de Docusaurus avec @canary
npm dist tag
Des problèmes ?
Demandez de l'aide sur Stack Overflow, sur notre dépôt GitHub, notre serveur Discord, ou Twitter.