Next.js - डायनेमिक रूटिंग

Next.js में, हम गतिशील रूप से मार्ग बना सकते हैं। इस उदाहरण में, हम मक्खी और उनकी रूटिंग पर पेज बनाएंगे।

  • Step 1. Define [id].js file- [आईडी] .js डायनामिक पृष्ठ का प्रतिनिधित्व करता है जहां आईडी सापेक्ष पथ होगा। इस फाइल को पेज / पोस्ट डायरेक्टरी में परिभाषित करें।

  • Step 2. Define lib/posts.js- posts.js आईडी और सामग्री का प्रतिनिधित्व करता है। रूट डाइरेक्टरी को रूट डायरेक्टरी में बनाया जाना है।

[Id] .js

[Id] .js फ़ाइल को getStaticPaths () पद्धति से अपडेट करें जो id के आधार पर सामग्री प्राप्त करने के लिए पथ और getStaticProps () विधि सेट करती है।

import Link from 'next/link'
import Head from 'next/head'
import Container from '../../components/container'

import { getAllPostIds, getPostData } from '../../lib/posts'

export default function Post({ postData }) {
   return (
      <Container>
         {postData.id}
         <br />
         {postData.title}
         <br />
         {postData.date}
      </Container>
   )
}
export async function getStaticPaths() {
   const paths = getAllPostIds()
   return {
      paths,
      fallback: false
   }
}

export async function getStaticProps({ params }) {
   const postData = getPostData(params.id)
      return {
      props: {
         postData
      }
   }
}

posts.js

Posts.js में id पाने के लिए getAllPostIds () और संबंधित सामग्री प्राप्त करने के लिएPPDData () शामिल हैं।

export function getPostData(id) {
   const postOne = {
      title: 'One',
      id: 1,
      date: '7/12/2020'
   }

   const postTwo = {
      title: 'Two',
      id: 2,
      date: '7/12/2020'
   }
   if(id == 'one'){
      return postOne;
   }else if(id == 'two'){
      return postTwo;
   }  
}

export function getAllPostIds() {
   return [{
      params: {
         id: 'one'
      }
   },
   {
      params: {
         id: 'two'
      }
   }
];
}

Next.js सर्वर प्रारंभ करें

सर्वर शुरू करने के लिए निम्नलिखित कमांड चलाएँ -।

npm run dev
> [email protected] dev \Node\nextjs
> next

ready - started server on http://localhost:3000
event - compiled successfully
event - build page: /
wait  - compiling...
event - compiled successfully
event - build page: /next/dist/pages/_error
wait  - compiling...
event - compiled successfully

आउटपुट सत्यापित करें

ओपन लोकलहोस्ट: ब्राउजर में 3000 / पोस्ट / एक और आपको निम्न आउटपुट दिखाई देगा।

ओपन लोकलहोस्ट: एक ब्राउज़र में 3000 / पोस्ट / दो और आपको निम्न आउटपुट दिखाई देगा।