АКЦИЯ: бесплатные месячные курсы по созданию сайтов
на выбор: верстка, JavaScript, PHP, Python или фреймворки. Сегодня последний день для записи! Жми!
⊗jsnxPmNvDL 48 of 57 menu
Новый формат обучения! Репетиторство по программированию. Есть еще 3 свободных места! Жми для подробностей.

Динамическая генерация ссылок в 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 - конкретный юзер по его айди.

Для этого сделаем следующую файловую структуру:

  • /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 передается айди несуществующего продукта, на экран выводилась 404 ошибка.

byru