Next.js - रूटिंग

Next.js फ़ाइल सिस्टम आधारित राउटर का उपयोग करता है। जब भी हम किसी पेज को जोड़ते हैंpagesनिर्देशिका, यह स्वचालित रूप से url के माध्यम से उपलब्ध है। इस राउटर के नियम निम्नलिखित हैं।

  • Index Routes- निर्देशिका के रूट के लिए एक फ़ोल्डर नक्शे में मौजूद एक index.js फ़ाइल। उदाहरण के लिए -

    • पेज / index.js के नक्शे '/' के लिए।

    • पेज / पोस्ट / index.js के नक्शे '/ पोस्ट'।

  • Nested Routes- पेज डायरेक्टरी में कोई नेस्टेड फोल्डर स्ट्रक्चर क्योंकि राउटर यूआरएल अपने आप आ जाता है। उदाहरण के लिए -

    • पेज / सेटिंग्स / डैशबोर्ड / about.js नक्शे '/ सेटिंग्स / डैशबोर्ड / के बारे में'।

    • पेज / पोस्ट / First.js के नक्शे '/ पोस्ट / पहले'।

  • Dynamic Routes- हम url से मिलान करने के लिए नामित पैरामीटर का उपयोग कर सकते हैं। उसी के लिए कोष्ठक का प्रयोग करें। उदाहरण के लिए -

    • पृष्ठ / पोस्ट / [आईडी] .js नक्शे '/ पदों /: आईडी' जहां हम 'जैसे पोस्ट / 1' URL का उपयोग कर सकते हैं।

    • पृष्ठ / [उपयोगकर्ता] /settings.js के नक्शे '/ पदों /: उपयोगकर्ता / सेटिंग्स' जहाँ हम '/ abc / सेटिंग्स' जैसे URL का उपयोग कर सकते हैं।

    • पृष्ठ / पोस्ट / [... सभी] .js के नक्शे '/ पोस्ट / *' जहां हम किसी भी यूआरएल जैसे '/ पोस्ट / 2020 / जून /' का उपयोग कर सकते हैं।

पेज लिंकिंग

Next.JS लिंक प्रतिक्रिया घटक का उपयोग करके क्लाइंट पक्ष पर पृष्ठों को लिंक करने की अनुमति देता है। इसके निम्नलिखित गुण हैं -

  • href- पेज डायरेक्टरी में पेज का नाम। उदाहरण के लिए/posts/first जो पृष्ठों / पोस्ट निर्देशिका में मौजूद First.js को संदर्भित करता है।

उसी को प्रदर्शित करने के लिए एक उदाहरण बनाते हैं।

इस उदाहरण में, हम डेटा प्राप्त करने के लिए सर्वर हिट करने के लिए index.js और first.js पेज अपडेट करेंगे।

चलिए ग्लोबल सीएसएस सपोर्ट चैप्टर में प्रयुक्त नेक्स्ट प्रोजेक्ट को अपडेट करते हैं ।

निम्नलिखित के रूप में पृष्ठ निर्देशिका में index.js फ़ाइल को अपडेट करें।

import Link from 'next/link'
import Head from 'next/head'

function HomePage(props) {
   return (
      <>
         <Head>
            <title>Welcome to Next.js!</title>
         </Head>
         <div>Welcome to Next.js!</div>
         <Link href="/posts/first">> <a>First Post</a></Link>
         <br/>
         <div>Next stars: {props.stars}</div>
         <img src="/logo.png" alt="TutorialsPoint Logo" />
      </>	    
   )
}

export async function getServerSideProps(context) {
   const res = await fetch('https://api.github.com/repos/vercel/next.js')
   const json = await res.json()
   return {
      props: { stars: json.stargazers_count }
   }
}

export default HomePage

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 और आपको निम्न आउटपुट दिखाई देगा।

फर्स्ट पोस्ट लिंक पर क्लिक करें।