azovl
@azovl

Хук useParams при тестировании React компонента выдает undefined, как исправить?

Есть компонент который получает идентификатор по URL используя хук useParams?
import {useParams} from "react-router-dom";

function SingleVideo() {
    const {id} = useParams();


Есть route к данному компоненту:
<Route path="/v/:id" component={SingleVideo} />

Код который использовал для тестирования:
const history = createMemoryHistory()
    const route = `/v/${contentBackup['video-list'][0]['video_id']}`;
    history.push(route)

    render(
        <Router path={`/v/${contentBackup['video-list'][0]['video_id']}`} history={history}>
            <SingleVideo />
        </Router>,
    );


Проблема в том, что при тестировании - useParams возвращает undefined. Как это исправить?
  • Вопрос задан
  • 587 просмотров
Решения вопроса 1
@markak
Frontend developer
Вы передаете атрибут path в компонент Router, но нужно передавать этот атрибут в компонент Route

https://v5.reactrouter.com/web/api/Route - по доке есть атрибут path
https://v5.reactrouter.com/web/api/Router - по доке нет атрибута path

также используйте базовый пример из доки:
https://v5.reactrouter.com/web/example/basic
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
23 нояб. 2024, в 01:31
1000 руб./за проект
23 нояб. 2024, в 00:16
2000 руб./за проект