⊗jsnxPmNvDL 48 of 57 menu

Generarea dinamică a linkurilor în NextJS

Să presupunem că avem un fișier cu datele utilizatorilor:

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

Să creăm două componente. Primul component va afișa lista utilizatorilor cu linkuri către descrierea lor detaliată. Al doilea component va afișa această descriere detaliată.

Să presupunem că la URL /users/list va fi afișată lista tuturor utilizatorilor, iar la URL /users/show/:id - un utilizator specific după id-ul său.

Pentru aceasta, să creăm următoarea structură de fișiere:

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

Să creăm primul component, în care vom genera dinamic linkuri într-o buclă, substituind în ele id fiecărui utilizator:

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

Să creăm componentul pentru afișarea unui utilizator specific după id-ul său:

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

Este dat următorul array:

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

Creați două componente. Să afișeze primul lista produselor sub formă de linkuri către descrierea completă a produsului. Să afișeze al doilea component descrierea detaliată a produsului.

Faceți ca atunci când în URL este transmis id-ul unui produs inexistent, pe ecran să fie afișată eroarea 404.

Română
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Folosim cookie pentru funcționarea site-ului, analiză și personalizare. Prelucrarea datelor are loc în conformitate cu Politica de confidențialitate.
acceptă toate configurează respinge