⊗jsnxPmNvDL 48 of 57 menu

Дынамічная генерацыя спасылак у NextJS

Няхай у нас ёсць нейкі файл з данымі карыстальнікаў:

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

Давайце зробім два кампаненты. Першы кампанент будзе паказваць спіс карыстальнікаў са спасылкамі на іх падрабязнае апісанне. Другі кампанент будзе выводзіць гэта падрабязнае апісанне.

Няхай па URL /by/users/list будзе паказвацца спіс усіх карыстальнікаў, а па URL /by/users/show/:id - канкрэтны карыстальнік па яго id.

Для гэтага зробім наступную файлаўую структуру:

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

Стварым першы кампанент, у якім будзем дынамічна генераваць спасылкі ў цыкле, падстаўляючы ў іх id каждага карыстальніка:

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

Зробім кампанент для вываду пэўнага карыстальніка па яго 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>; }

Дадзены наступны масіў:

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

Зрабіце два кампаненты. Няхай першы паказвае спіс прадуктаў у выглядзе спасылак на поўнае апісанне прадукту. Няхай другі кампанент паказвае падрабязнае апісанне прадукту.

Зрабіце так, каб, калі ў URL перадаецца id неіснуючага прадукту, на экран выводзілася 404 памылка.

Беларуская
AfrikaansAzərbaycanБългарскиবাংলাČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Мы выкарыстоўваем cookie для працы сайта, аналітыкі і персаналізацыі. Апрацоўка дадзеных адбываецца згодна Палітыкай канфідэнцыяльнасці.
прыняць усе наладзіць адхіліць