⊗jsnxPmNvDL 48 of 57 menu

Dinamikus linkgenerálás NextJS-ben

Tegyük fel, hogy van egy fájlunk felhasználói adatokkal:

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

Készítsünk két komponenst. Az első komponens megjeleníti a felhasználók listáját linkekkel az ő részletes leírásukhoz. A második komponens kiírja ezt a részletes leírást.

Legyen a /users/list URL-en az összes felhasználó listája, a /users/show/:id URL-en pedig egy adott felhasználó az ő azonosítójával.

Ehhez készítsük el a következő fájlszerkezetet:

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

Készítsük el az első komponenst, amelyben dinamikusan generálunk linkeket egy ciklusban, beillesztve beléjük id minden felhasználó:

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

Készítsük el a komponenst egy adott felhasználó kiíratásához az ő id azonosítója alapján:

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

Adott a következő tömb:

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

Készítsen két komponenst. Legyen az első a termékek listáját linkek formájában a termék teljes leírásához. Legyen a második komponens a termék részletes leírásának megjelenítésére.

Állítsa be, hogy ha a URL-ben egy nem létező termék azonosítója kerül átadásra, a képernyőn 404 hiba jelenjen meg.

Magyar
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
A weboldal működéséhez, elemzéshez és személyre szabáshoz sütiket használunk. Az adatfeldolgozás a Adatvédelmi irányelvek szerint történik.
összes elfogadása beállítás elutasítás