⊗jsnxPmNvDL 48 of 57 menu

Gjenerimi Dinamik i Lidhjeve në NextJS

Le të themi se kemi një skedar me të dhënat e përdoruesve:

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

Le të krijojmë dy komponentë. Komponenti i parë do të shfaqë listën e përdoruesve me lidhje për përshkrimin e tyre të detajuar. Komponenti i dytë do të shfaqë atë përshkrim të detajuar.

Le të themi se në URL /users/list shfaqet lista e të gjithë përdoruesve, dhe në URL /users/show/:id - shfaqet një përdorues specifik sipas id-së së tij.

Për këtë, le të krijojmë strukturën e mëposhtme të skedarëve:

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

Le të krijojmë komponentin e parë, ku do të gjenerojmë në mënyrë dinamike lidhjet në një cikël, duke vendosur në to id e çdo përdoruesi:

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>; }

Le të krijojmë komponentin për të shfaqur përdoruesin e caktuar sipas id të tij:

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>; }

Jepet array-i i mëposhtëm:

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', }, ];

Krijoni dy komponentë. Le të komponenti i parë të shfaqë listën e produkteve në formën e lidhjeve për përshkrimin e plotë të produktit. Le të komponenti i dytë të shfaqë përshkrimin e detajuar të produktit.

Bëni që, nëse në URL kallet një id e një produkti që nuk ekziston, të shfaqet në ekran një gabim 404.

Shqip
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Ne përdorim cookie për funksionimin e sajtit, analizën dhe personalizimin. Përpunimi i të dhënave bëhet në përputhje me Politikën e Privatësisë.
prano të gjitha konfiguro refuzo