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

Եկեք ստեղծենք երկու կոմպոնենտ. Առաջին կոմպոնենտը կցուցադրի օգտատերերի ցուցակը՝ հղումներով դեպի նրանց մանրամասն նկարագրությունը: Երկրորդ կոմպոնենտը կցուցադրի այդ մանրամասն նկարագրությունը:

Ենթադրենք՝ /users/list URL-ով կցուցադրվի բոլոր օգտատերերի ցուցակը, իսկ /users/show/:id URL-ով՝ կոնկրետ օգտատերը՝ ըստ նրա 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हिन्दीMagyarIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Մենք օգտագործում ենք cookie-ներ կայքի աշխատանքի, վերլուծության և անհատականացման համար։ Տվյալների մշակումը կատարվում է համաձայն Գաղտնիության քաղաքականության։
ընդունել բոլորը կարգավորել մերժել