⊗jsnxPmNvDL 48 of 57 menu

Geração Dinâmica de Links em NextJS

Suponha que temos um arquivo com dados de usuários:

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

Vamos criar dois componentes. O primeiro componente mostrará uma lista de usuários com links para seus detalhes. O segundo componente exibirá esses detalhes.

Suponha que a URL /users/list mostre a lista de todos os usuários, e a URL /users/show/:id - um usuário específico pelo seu id.

Para isso, faremos a seguinte estrutura de arquivos:

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

Criaremos o primeiro componente, no qual geraremos dinamicamente links em um loop, inserindo o id de cada usuário:

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

Vamos fazer o componente para exibir um usuário específico pelo seu 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>; }

Dado o seguinte array:

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

Crie dois componentes. Suponha que o primeiro mostre a lista de produtos na forma de links para a descrição completa do produto. Suponha que o segundo componente mostre a descrição detalhada do produto.

Faça com que, se um id de produto inexistente for passado na URL, seja exibido um erro 404 na tela.

Português
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Nós usamos cookies para o funcionamento do site, análises e personalização. O processamento de dados é realizado de acordo com a Política de Privacidade.
aceitar todas configurar rejeitar