⊗jsnxPmNvDL 48 of 57 menu

Dinamičko generisanje linkova u NextJS

Pretpostavimo da imamo određeni fajl sa podacima o korisnicima:

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

Napravimo dve komponente. Prva komponenta će prikazivati listu korisnika sa linkovima na njihov detaljan opis. Druga komponenta će prikazati taj detaljan opis.

Neka se na URL /users/list prikaže lista svih korisnika, a na URL /users/show/:id - konkretan korisnik po njegovom id-u.

Za ovo ćemo napraviti sledeću fajl strukturu:

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

Kreirajmo prvu komponentu, u kojoj ćemo dinamički generisati linkove u petlji, ubacujući u njih id svakog korisnika:

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

Napravimo komponentu za prikaz određenog korisnika po njegovom 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>; }

Dat je sledeći niz:

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

Napravite dve komponente. Neka prva prikaže listu proizvoda u obliku linkova na pun opis proizvoda. Neka druga komponenta prikaže detaljan opis proizvoda.

Učinite tako da, ako se u URL-u prosledi id nepostojećeg proizvoda, na ekranu ispiše 404 greška.

Srpski
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Koristimo kolačiće za rad sajta, analitiku i personalizaciju. Obrada podataka se vrši u skladu sa Politikom privatnosti.
prihvati sve podesi odbij