Table des matières
Installer
concept de pages
Page dynamique
API du blog, incluse, dispositions, page d'accueil, page de blog, déploiement de l'environnement de production, suggestions d'amélioration
Maison interface Web tutoriel CSS Construire un blog avec next.js

Construire un blog avec next.js

Apr 04, 2025 am 10:29 AM

Construire un blog avec next.js

Cet article vous guidera pour créer un cadre de blog statique en utilisant Next.js, avec conception et structure inspirées de Jekyll. Jekyll est connu pour sa facilité d'accès et sa grande contrôlabilité, et cet article vise à profiter de Next.js et à réagir pour fournir une nouvelle solution de construction de blog statique. Next.js est basé sur le système de fichiers et simplifie le processus de construction des sites Web statiques.

Une structure de répertoire de blog Jekyll typique est la suivante:

 <code>. ├─── _posts/      ...Markdown 格式的博文├─── _layouts/     ...不同页面的布局├─── _includes/    ...可复用的组件├─── index.md     ...主页└─── config.yml    ...博客配置</code>
Copier après la connexion

Notre cadre suivra autant que possible cette structure de répertoire pour faciliter la migration des blogs de Jekyll, réutilisez simplement les publications et les configurations.

Si vous n'êtes pas familier avec Jekyll, c'est un générateur de sites statique qui convertit le texte brut en sites Web et blogs statiques. Veuillez vous référer au Guide de démarrage rapide Jekyll pour plus de détails.

Cet article suppose que vous avez les bases de React. Sinon, reportez-vous au Guide React Gettant.

Installer

Next.js est basé sur React et écrit dans Node.js. Par conséquent, vous devez installer NPM avant d'ajouter Suivant.js, React et React-Dom.

 <code>mkdir nextjs-blog && cd $_ npm init -y npm install next react react-dom --save</code>
Copier après la connexion

Afin d'exécuter le script suivant.js sur la ligne de commande, nous devons ajouter la commande suivante à la section scripts de package.json.

 <code>"scripts": { "dev": "next" }</code>
Copier après la connexion

Maintenant, exécutez la commande npm run dev pour la première fois et voyez ce qui se passe.

 <code>$ npm run dev > [email protected] dev /~user/nextjs-blog > next ready - started server on https://www.php.cn/link/4a914e5c38172ae9b61780ffbd0b2f90 Error: > Couldn't find a `pages` directory. Please create one under the project root</code>
Copier après la connexion

Le compilateur invite le répertoire des pages sous le répertoire racine du projet. Nous apprendrons le concept des pages dans la section suivante.

concept de pages

Next.js est construit en fonction du concept Pages. Chaque page est un composant React (.js ou .jsx) qui est mappé sur l'itinéraire en fonction du nom du fichier. Par exemple:

<code>               路由----               ----- /pages/about.js         /about /pages/projects/work1.js     /projects/work1 /pages/index.js         /</code>
Copier après la connexion

Créons le répertoire des pages dans le répertoire des racines du projet et remplissons le premier page index.js avec le composant React Basic.

 <code>// pages/index.js export default function Blog() { return</code> bienment sur le blog Next.js
}
Copier après la connexion

Exécutez npm run dev pour démarrer le serveur et visitez https://www.php.cn/link/4a914e5c38172ae9b61780ffbd0b2f90 dans votre navigateur pour afficher votre blog.

Hors de la boîte, nous obtenons:

  • Rechargement chaud, pas besoin de rafraîchir le navigateur pour chaque changement de code.
  • / pages / ** Génération statique de toutes les pages du répertoire.
  • / Public / ** Service de fichiers statique pour les ressources dans le répertoire.
  • Page d'erreur 404.

Visitez n'importe quel chemin sur localhost pour voir l'effet réel de la page 404. Si vous devez personnaliser la page 404, veuillez vous référer à la documentation suivante.

Page dynamique

Les pages de routage statiques sont utilisées pour construire des pages d'accueil, sur des pages, etc. Par exemple:

<code>             路由----             ----- /pages/posts/[slug].js    /posts/1              /posts/abc              /posts/hello-world</code>
Copier après la connexion

Tous les itinéraires, tels que / poteaux / 1, / poteaux / ABC, etc., correspondront / postes / postes/ormais / moustiquaire, et le paramètre Slug sera envoyé à la page en tant que paramètre de requête. Ceci est particulièrement utile pour nos articles de blog, car nous ne voulons pas créer de fichier pour chaque article de blog; Au lieu de cela, nous pouvons passer dynamiquement les limaces pour rendre le billet de blog correspondant.

(Le contenu suivant est omis. Parce que la longueur de l'article est trop longue, le texte d'origine restera inchangé et que les pièces restantes seront simplifiées et les images seront conservées)

API du blog, incluse, dispositions, page d'accueil, page de blog, déploiement de l'environnement de production, suggestions d'amélioration

La partie ultérieure de l'article détaille comment créer une API de blog (obtenir tous les articles de blog, obtenir des articles de blog individuels et configurer l'analyse), créer des composants réutilisables (incluse), une disposition de page de conception (disposition), mettre en œuvre des listes de articles de blog et quelques suggestions de blog individuelles, des pages de billets de syntax, des labels de classification d'articles et des labels de classification de la pagination, des détails sur la pagination, des produits de mise en évidence de la pagination, des détails sur la mise en évidence, les détails de la pagination, les produits de mise en évidence, les détails de la pagination, les détails de la mise en évidence, les détails de la mise en œuvre de l'Emplementation. sont basés sur les fonctionnalités et les fonctionnalités de Next.js et utilisent pleinement ses capacités de génération de sites statiques.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

<🎜>: Grow A Garden - Guide de mutation complet
3 Il y a quelques semaines By DDD
<🎜>: Bubble Gum Simulator Infinity - Comment obtenir et utiliser les clés royales
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Système de fusion, expliqué
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Comment déverrouiller le grappin
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Tutoriel Java
1664
14
Tutoriel PHP
1269
29
Tutoriel C#
1249
24
Une preuve de concept pour rendre Sass plus rapidement Une preuve de concept pour rendre Sass plus rapidement Apr 16, 2025 am 10:38 AM

Au début d'un nouveau projet, la compilation SASS se produit en un clin d'œil. Cela se sent bien, surtout quand il est associé à BrowSersync, qui recharge

Une comparaison des fournisseurs de formulaires statiques Une comparaison des fournisseurs de formulaires statiques Apr 16, 2025 am 11:20 AM

Essayons de savoir un terme ici: "fournisseur de formulaire statique". Vous apportez votre HTML

Actualités hebdomadaires de la plate-forme: attribut HTML Loading, les principales spécifications Aria et le passage de iframe à Shadow Dom Actualités hebdomadaires de la plate-forme: attribut HTML Loading, les principales spécifications Aria et le passage de iframe à Shadow Dom Apr 17, 2025 am 10:55 AM

Dans cette semaine, le Roundup des nouvelles de la plate-forme, Chrome présente un nouvel attribut pour le chargement, les spécifications d'accessibilité pour les développeurs Web et la BBC Moves

L'accord avec l'élément de section L'accord avec l'élément de section Apr 12, 2025 am 11:39 AM

Deux articles ont publié exactement le même jour:

Multipliers multiples: cas général Multipliers multiples: cas général Apr 12, 2025 am 10:52 AM

La première partie de cette série en deux parties a expliqué comment nous pouvons obtenir un curseur à deux pouces. Maintenant, nous examinerons un cas multi-tronçon général, mais avec un autre et

Certains pratiques avec l'élément de dialogue HTML Certains pratiques avec l'élément de dialogue HTML Apr 16, 2025 am 11:33 AM

C'est moi qui regarde l'élément HTML pour la première fois. J'en ai été conscient depuis un certain temps, mais il ne l'a pas encore pris pour un tour. Il a un peu cool et

Comment nous avons tagué Google Fonts et créé des goofont.com Comment nous avons tagué Google Fonts et créé des goofont.com Apr 12, 2025 pm 12:02 PM

Goofonts est un projet parallèle signé par un développeur-femme et un concepteur-mari, tous deux de grands fans de typographie. Nous avons marqué Google

C'est tout dans la tête: gérer la tête de document d'un site alimenté par réact avec un casque React C'est tout dans la tête: gérer la tête de document d'un site alimenté par réact avec un casque React Apr 15, 2025 am 11:01 AM

Le chef de document n'est peut-être pas la partie la plus glamour d'un site Web, mais ce qui y va est sans doute tout aussi important pour le succès de votre site Web que son

See all articles