Next.js - Dynamic Routing
W Next.js możemy dynamicznie tworzyć trasy. W tym przykładzie utworzymy strony w locie i ich routing.
- Step 1. Define [id].js file- [id] .js reprezentuje dynamiczną stronę, gdzie id będzie ścieżką względną. Zdefiniuj ten plik w katalogu pages / post. 
- Step 2. Define lib/posts.js- posts.js reprezentuje identyfikatory i zawartość. Katalog lib ma zostać utworzony w katalogu głównym. 
[id] .js
Zaktualizuj plik [id] .js za pomocą metody getStaticPaths (), która ustawia ścieżki i metodę getStaticProps (), aby pobrać zawartość na podstawie identyfikatora.
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 zawiera getAllPostIds (), aby pobrać identyfikatory i getPostData (), aby pobrać odpowiednią zawartość.
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'
      }
   }
];
}Uruchom serwer Next.js
Uruchom następujące polecenie, aby uruchomić serwer -.
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 successfullySprawdź wyjście
Otwórz localhost: 3000 / posty / jeden w przeglądarce, a zobaczysz następujące dane wyjściowe.
 
                Otwórz localhost: 3000 / posts / two w przeglądarce, a zobaczysz następujący wynik.
