Maison >interface Web >js tutoriel >Maîtrise des entretiens Next.js : questions essentielles (partie 6)
Libérez tout votre potentiel en maîtrisant Next.js avec le guide d'entretien Next.js : 100 questions et réponses pour réussir ?. Que vous débutiez en tant que développeur ou que vous soyez un professionnel expérimenté cherchant à faire passer vos compétences au niveau supérieur, cet e-book complet est conçu pour vous aider à réussir les entretiens Next.js et à devenir un collaborateur confiant et prêt à travailler. promoteur. Le guide couvre un large éventail de sujets Next.js, garantissant que vous êtes bien préparé pour toute question qui pourrait vous être posée. Cet e-book explore des concepts clés tels que le rendu côté serveur (SSR) ?, la génération de sites statiques (SSG ) ?, Régénération statique incrémentielle (ISR) ⏳, Routeur d'application ?️, Récupération de données ?, et bien plus encore. Chaque sujet est expliqué en détail, offrant des exemples concrets et des réponses détaillées aux questions d'entretien les plus fréquemment posées. En plus de répondre aux questions, le guide met en avant les bonnes pratiques ✅ pour optimiser vos applications Next.js, améliorer les performances ⚡ et assurer l'évolutivité ?. Avec Next.js en constante évolution, nous approfondissons également les fonctionnalités de pointe telles que React 18, Concurrent Rendering et Suspense ?. Cela garantit que vous êtes toujours au courant des dernières avancées et que vous disposez des connaissances recherchées par les enquêteurs. Ce qui distingue ce guide est son approche pratique. Il ne couvre pas seulement la théorie, mais fournit des informations exploitables que vous pouvez appliquer directement à vos projets. La sécurité ?, l'optimisation du référencement ? et les pratiques de déploiement ?️ sont également explorées en détail pour garantir que vous êtes prêt pour le cycle de vie complet du développement. Que vous vous prépariez pour un entretien technique dans une entreprise de haute technologie ou que vous cherchiez à construire plus efficacement, applications évolutives, ce guide vous aidera à perfectionner vos compétences Next.js et à vous démarquer de la concurrence. À la fin de ce livre, vous serez prêt à aborder n'importe quelle question d'entretien Next.js en toute confiance, des concepts fondamentaux aux défis de niveau expert. Équipez-vous des connaissances nécessaires pour exceller en tant que développeur Next.js ? et saisissez en toute confiance votre prochaine opportunité de carrière !
GraphQL peut être utilisé dans Next.js pour interroger le contenu d'un CMS sans tête ou de n'importe quel point de terminaison GraphQL. Next.js vous permet de récupérer des données de GraphQL lors de la génération statique (avec getStaticProps), du rendu côté serveur (avec getServerSideProps) ou côté client (avec des hooks comme Apollo Client ou URQL).
Exemple avec graphql-request :
import { request } from 'graphql-request'; export async function getStaticProps() { const query = `{ posts { id title content } }`; const data = await request('<https:>', query); return { props: { posts: data.posts, }, }; } export default function PostsPage({ posts }) { return ( <div> {posts.map(post => ( <div key="{post.id}"> <h2>{post.title}</h2> <p>{post.content}</p> </div> ))} </div> ); } </https:>
Apollo Client est une bibliothèque populaire pour travailler avec GraphQL. Il peut être facilement intégré à une application Next.js pour récupérer des données côté serveur et côté client.
Étapes pour intégrer Apollo Client :
Installer les dépendances :
npm install @apollo/client graphql
Configurer le client Apollo :
Créez un fichier apolloClient.js pour configurer le client Apollo :
// lib/apolloClient.js import { ApolloClient, InMemoryCache, HttpLink } from '@apollo/client'; const client = new ApolloClient({ link: new HttpLink({ uri: '<https:>' }), cache: new InMemoryCache(), }); export default client; </https:>
Utiliser le client Apollo dans les pages :
Utilisez le client Apollo avec getStaticProps, getServerSideProps ou sur le client à l'aide du hook useQuery d'Apollo.
Exemple utilisant getStaticProps :
import { ApolloClient, InMemoryCache, gql } from '@apollo/client'; import client from '../lib/apolloClient'; const GET_POSTS = gql` query GetPosts { posts { id title } } `; export async function getStaticProps() { const { data } = await client.query({ query: GET_POSTS }); return { props: { posts: data.posts, }, }; } export default function PostsPage({ posts }) { return ( <div> {posts.map(post => ( <div key="{post.id}"> <h2>{post.title}</h2> </div> ))} </div> ); }
Dans Next.js, vous pouvez effectuer des redirections côté serveur en utilisant la redirection dans getServerSideProps ou generateStaticParams pour la redirection au niveau de la page.
Exemple :
export async function getServerSideProps(context) { // Check some condition, like user authentication const isAuthenticated = false; if (!isAuthenticated) { return { redirect: { destination: '/login', permanent: false, // Optional: set to true for permanent redirects }, }; } return { props: {}, // Will pass to the component }; }
Exemple :
// next.config.js module.exports = { async redirects() { return [ { source: '/old-page', destination: '/new-page', permanent: true, }, ]; }, };
Cette configuration redirigera /old-page vers /new-page de manière permanente une fois déployée.
Ces méthodes vous permettent de gérer les redirections basées à la fois sur les conditions côté serveur et les configurations statiques dans Next.js.
Le hook useRouter de Next.js est utilisé pour accéder à l'objet routeur dans les composants fonctionnels. Il donne accès à l'itinéraire actuel, aux paramètres de requête, au nom de chemin et aux méthodes de navigation. Il est généralement utilisé pour obtenir des informations sur l'itinéraire actuel ou pour naviguer par programme vers d'autres itinéraires.
Exemple d'utilisation :
'use client'; // Required for client-side hooks import { useRouter } from 'next/router'; export default function MyComponent() { const router = useRouter(); const handleClick = () => { // Navigate programmatically to another route router.push('/about'); }; return ( <div> <p>Current Path: {router.pathname}</p> <button onclick="{handleClick}">Go to About Page</button> </div> ); }
Propriétés et méthodes communes :
Vous pouvez naviguer par programme dans Next.js à l'aide du hook useRouter ou du composant Link.
Utilisation du hook useRouter :
La méthode router.push() peut être utilisée pour naviguer par programme vers une nouvelle page.
Exemple :
import { request } from 'graphql-request'; export async function getStaticProps() { const query = `{ posts { id title content } }`; const data = await request('<https:>', query); return { props: { posts: data.posts, }, }; } export default function PostsPage({ posts }) { return ( <div> {posts.map(post => ( <div key="{post.id}"> <h2>{post.title}</h2> <p>{post.content}</p> </div> ))} </div> ); } </https:>
Utilisation du composant Link (pour la navigation déclarative) :
npm install @apollo/client graphql
Utilisation de router.replace() :
Si vous souhaitez naviguer sans ajouter la nouvelle page à la pile de l'historique du navigateur, utilisez router.replace().
next-i18next est une bibliothèque populaire qui fournit la prise en charge de l'internationalisation (i18n) pour Next.js. Il permet de gérer les traductions dans plusieurs langues et simplifie le processus de configuration de la localisation.
Étapes pour utiliser next-i18next :
Installer le package :
// lib/apolloClient.js import { ApolloClient, InMemoryCache, HttpLink } from '@apollo/client'; const client = new ApolloClient({ link: new HttpLink({ uri: '<https:>' }), cache: new InMemoryCache(), }); export default client; </https:>
Configurer le next-i18next :
Dans next.config.js, configurez les paramètres régionaux pris en charge et la langue par défaut.
import { ApolloClient, InMemoryCache, gql } from '@apollo/client'; import client from '../lib/apolloClient'; const GET_POSTS = gql` query GetPosts { posts { id title } } `; export async function getStaticProps() { const { data } = await client.query({ query: GET_POSTS }); return { props: { posts: data.posts, }, }; } export default function PostsPage({ posts }) { return ( <div> {posts.map(post => ( <div key="{post.id}"> <h2>{post.title}</h2> </div> ))} </div> ); }
Créer des fichiers de traduction :
Dans votre projet, créez un dossier appelé public/locales et ajoutez des fichiers JSON pour chaque langue.
export async function getServerSideProps(context) { // Check some condition, like user authentication const isAuthenticated = false; if (!isAuthenticated) { return { redirect: { destination: '/login', permanent: false, // Optional: set to true for permanent redirects }, }; } return { props: {}, // Will pass to the component }; }
Utiliser les traductions dans les composants :
Utilisez le hook useTranslation fourni par next-i18next pour obtenir des traductions.
// next.config.js module.exports = { async redirects() { return [ { source: '/old-page', destination: '/new-page', permanent: true, }, ]; }, };
La localisation dans Next.js peut être implémentée à l'aide de next-i18next, qui gère la traduction du contenu de votre application. Voici un bref guide :
Créer des fichiers spécifiques à une langue :
Chaque langue aura son propre fichier de traduction dans le répertoire public/locales. Par exemple, pour l'anglais et l'espagnol :
'use client'; // Required for client-side hooks import { useRouter } from 'next/router'; export default function MyComponent() { const router = useRouter(); const handleClick = () => { // Navigate programmatically to another route router.push('/about'); }; return ( <div> <p>Current Path: {router.pathname}</p> <button onclick="{handleClick}">Go to About Page</button> </div> ); }
Accédez aux traductions en utilisant useTranslation :
Utilisez le hook useTranslation pour accéder aux traductions dans n’importe quel composant.
import { useRouter } from 'next/router'; function NavigateButton() { const router = useRouter(); const handleNavigation = () => { router.push('/new-page'); // Navigates to a new page }; return <button onclick="{handleNavigation}">Go to New Page</button>; }
Configurer le changement de langue :
Vous pouvez fournir un sélecteur de langue pour permettre aux utilisateurs de basculer entre les langues.
import { request } from 'graphql-request'; export async function getStaticProps() { const query = `{ posts { id title content } }`; const data = await request('<https:>', query); return { props: { posts: data.posts, }, }; } export default function PostsPage({ posts }) { return ( <div> {posts.map(post => ( <div key="{post.id}"> <h2>{post.title}</h2> <p>{post.content}</p> </div> ))} </div> ); } </https:>
next-seo est une bibliothèque qui simplifie l'ajout de métadonnées SEO à votre application Next.js. Il fournit un ensemble de composants et de fonctions utilitaires pour gérer les métadonnées SEO telles que les titres, les descriptions et les balises Open Graph.
Étapes pour utiliser next-seo :
Installer le package :
npm install @apollo/client graphql
Ajoutez des métadonnées SEO à vos pages :
Vous pouvez utiliser le composant NextSeo pour ajouter des balises méta SEO à chaque page.
// lib/apolloClient.js import { ApolloClient, InMemoryCache, HttpLink } from '@apollo/client'; const client = new ApolloClient({ link: new HttpLink({ uri: '<https:>' }), cache: new InMemoryCache(), }); export default client; </https:>
Paramètres SEO globaux :
Vous pouvez configurer les paramètres de référencement globaux dans pages/_document.js pour appliquer les paramètres de référencement par défaut à toutes les pages.
Pour ajouter Google Analytics à votre projet Next.js, vous pouvez utiliser le composant next/script pour insérer le script Google Analytics dans le fichier
de vos pages.Étapes :
Exemple :
import { ApolloClient, InMemoryCache, gql } from '@apollo/client'; import client from '../lib/apolloClient'; const GET_POSTS = gql` query GetPosts { posts { id title } } `; export async function getStaticProps() { const { data } = await client.query({ query: GET_POSTS }); return { props: { posts: data.posts, }, }; } export default function PostsPage({ posts }) { return ( <div> {posts.map(post => ( <div key="{post.id}"> <h2>{post.title}</h2> </div> ))} </div> ); }
Remarques :
SSR (Server-Side Rendering) et CSR (Client-Side Rendering) sont deux méthodes de rendu différentes dans Next.js.
SSR (rendu côté serveur) :
En SSR, la page est pré-rendue sur le serveur lors de la requête. Cela signifie que le HTML est généré sur le serveur et que la page entièrement rendue est envoyée au client. SSR est utile pour les pages qui doivent afficher du contenu dynamique et qui doivent être indexées par les moteurs de recherche ou qui nécessitent un chargement initial rapide des pages.
export async function getServerSideProps(context) { // Check some condition, like user authentication const isAuthenticated = false; if (!isAuthenticated) { return { redirect: { destination: '/login', permanent: false, // Optional: set to true for permanent redirects }, }; } return { props: {}, // Will pass to the component }; }
CSR (rendu côté client) :
En CSR, la page est entièrement rendue côté client. Le code HTML initial servi par le serveur est minime (généralement juste un squelette ou une page de chargement) et JavaScript est responsable du rendu du contenu. La RSE est utile pour les applications où le contenu change fréquemment en fonction de l'interaction de l'utilisateur.
Pour rendre une application Next.js compatible avec Progressive Web App (PWA), vous devez utiliser des service Workers, des fichiers manifestes et configurer votre application pour qu'elle soit installable.
Installer le plugin PWA :
Utilisez le plugin next-pwa pour configurer facilement PWA dans Next.js.
import { request } from 'graphql-request'; export async function getStaticProps() { const query = `{ posts { id title content } }`; const data = await request('<https:>', query); return { props: { posts: data.posts, }, }; } export default function PostsPage({ posts }) { return ( <div> {posts.map(post => ( <div key="{post.id}"> <h2>{post.title}</h2> <p>{post.content}</p> </div> ))} </div> ); } </https:>
Configurez next-pwa dans next.config.js :
npm install @apollo/client graphql
Ajouter un fichier manifeste :
Créez un manifest.json dans le répertoire public/ pour les icônes, la couleur du thème et d'autres propriétés de votre application :
// lib/apolloClient.js import { ApolloClient, InMemoryCache, HttpLink } from '@apollo/client'; const client = new ApolloClient({ link: new HttpLink({ uri: '<https:>' }), cache: new InMemoryCache(), }); export default client; </https:>
Ajouter un travailleur de service :
Le plugin next-pwa génère automatiquement un service worker et gère la mise en cache pour l'assistance hors ligne.
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!