⊗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 /users/list се показва списъкът с всички потребители, а на URL /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={`/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
Ние използваме бисквитки за работата на сайта, анализ и персонализация. Обработката на данни се извършва в съответствие с Политика за поверителност.
приемам всички настройки отхвърляне