⊗jsnxPmNvDL 48 of 57 menu

NextJS-də Dinamik Link Generasiyası

Tutaq ki, bizdə istifadəçilərin məlumatları olan bir fayl var:

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

Gəlin iki komponent düzəldək. Birinci komponent istifadəçilərin siyahısını onların ətraflı təsvirinə keçid linkləri ilə göstərsin. İkinci komponent isə bu ətraflı təsviri çıxarsın.

Tutaq ki, /users/list URL-i bütün istifadəçilərin siyahısını göstərsin, /users/show/:id URL-i isə müəyyən bir istifadəçini onun id-nə görə göstərsin.

Bunun üçün aşağıdakı fayl quruluşunu edək:

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

Birinci komponenti yaradaq, onda dinamik şəkildə dövr içərisində linklər generasiya edəcəyik, hər bir istifadəçinin id-ni onlara əvəz edərək:

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

Gəlin onun id-sinə görə müəyyən bir istifadəçini çıxarmaq üçün komponent edək:

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

Aşağıdakı massiv verilib:

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

İki komponent edin. Tutaq ki, birincisi məhsulların siyahısını məhsulun tam təsvirinə linklər şəklində göstərir. Tutaq ki, ikinci komponent məhsulun ətraflı təsvirini göstərir.

Elə edin ki, əgər URL-də mövcud olmayan məhsulun id-si ötürülərsə, ekranda 404 xətası çıxsın.

Azərbaycan
AfrikaansБългарскиবাংলাБеларускаяČ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
Biz saytin işi, analitika və fərdiləşdirmə üçün cookie istifadə edirik. Məlumatların emalı Məxfilik Siyasəti əsasında həyata keçirilir.
hamısını qəbul et konfiqurasiya et rədd et