Blog officiel du projet Web Apps Conception
layout: post title: ‘Premiers pas sur Next.js’ date: ‘2022-11-15T17:00:00.000Z’ tags: react next.js
Il s’agit du blog-starter plus TypeScript existant.
Ce blog présente la fonctionnalité de génération statique de Next.js en utilisant des fichiers Markdown comme source de données.
Les articles de blog sont stockés dans /_posts en tant que fichiers Markdown avec prise en charge des informations préliminaires. L’ajout d’un nouveau fichier Markdown créera un nouveau billet de blog.
Pour créer les articles de blog, nous utilisons remark et remark-html pour convertir les fichiers Markdown en une chaîne HTML, puis l’envoyons comme accessoire à la page. Les métadonnées de chaque publication sont gérées par gray-matter et également envoyées en accessoires à la page.
Si vous souhaitez publier et commenter vos codes source sur un blog, next.js permet de générer un modèle de blog en une simple commande.
yarn create next-app --example blog-starter blog-starter-app
Cet exemple montre comment utiliser Tailwind CSS avec Next.js. Il suit les étapes décrites dans les documents officiels de Tailwind.
yarn create next-app --example with-tailwindcss with-tailwindcss-app
Pour une meilleure lisibilité, nous devons mettre en évidence des groupes de texte spécifiques.
Heureusement, il existe une jolie petite bibliothèque qui le fait déjà pour nous, highlight.js.
Markdown-it a une option en surbrillance que nous pouvons facilement utiliser pour nous connecter.
Ainsi, il faut remplacer les composants remark
et remark-html
par highlight.js
et markdown-it
:
yarn remove remark remark-html
yarn add highlight.js markdown-it
Remplacer le fichier lib/markdownToHtml.ts par les lignes suivantes :
import hljs from 'highlight.js'
import Markdown from 'markdown-it'
export default async function markdownToHtml(markdown: string) {
const md = Markdown({
highlight: (
str: string,
lang: string,
) => {
const code = lang && hljs.getLanguage(lang)
? hljs.highlight(str, {
language: lang,
ignoreIllegals: true,
}).value
: md.utils.escapeHtml(str);
return `<pre class="hljs"><code>${code}</code></pre>`;
},
})
const result = md.render(markdown)
return result.toString()
}
Ajout du style CSS dans le fichier pages/_app.tsx :
import 'highlight.js/styles/stackoverflow-dark.css'
Ce blog utilise le framework Tailwind CSS, et peut être déployé facilement sur le cloud Vercel (Documentation).