⊗jsnxPmNvDL 48 of 57 menu

Dynamisk generering av lenker i NextJS

La oss si at vi har en fil med brukerdata:

export default users = [ { id: 1, name: 'name1', surn: 'surn1', }, { id: 2, name: 'name2', surn: 'surn2', }, { id: 3, name: 'name3', surn: 'surn3', }, ];

La oss lage to komponenter. Den første komponenten vil vise en liste over brukere med lenker til deres detaljerte beskrivelse. Den andre komponenten vil vise denne detaljerte beskrivelsen.

La URL-en /users/list vise listen over alle brukere, og URL-en /users/show/:id - en spesifikk bruker basert på deres id.

For å gjøre dette, la oss opprette følgende filstruktur:

  • /app/
    • /users/
      • users.js
      • /list/
        • page.jsx
      • /show/[id]/
        • page.jsx

La oss opprette den første komponenten, hvor vi dynamisk skal generere lenker i en loop, og sette inn id for hver bruker:

import users from '../users.js'; import Link from 'next/link'; export default function List() { let list = users.map(user => { return <li> <Link href={`/users/show/${user.id}`}> {user.name} </Link> </li>; }); return <ul> {list} </ul>; }

La oss lage en komponent for å vise en spesifikk bruker basert på deres id:

import users from '../../users.js'; export default function User({params}) { let user = users[params.id]; return <div> <span>{user.id}</span> <span>{user.name}</span> <span>{user.surn}</span> </div>; }

Følgende array er gitt:

let prods = [ { id: 1, name: 'prod1', cost: 100, desc: 'desc1', }, { id: 2, name: 'prod2', cost: 200, desc: 'desc2', }, { id: 3, name: 'prod3', cost: 300, desc: 'desc3', }, ];

Lag to komponenter. La den første vise en liste over produkter i form av lenker til en full beskrivelse av produktet. La den andre komponenten vise en detaljert beskrivelse av produktet.

Gjør slik at hvis en id for et ikke-eksisterende produkt sendes i URL-en, vises en 404 feil på skjermen.

Norsk
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Vi bruker informasjonskapsler for nettstedets funksjonalitet, analyse og personalisering. Behandling av data foregår i henhold til Personvernerklæringen.
godta alle tilpass avvis