Задать вопрос
@elep5

React router как проверить url шапки сайта на совпадение маршрута через match?

подскажите, есть структура маршрутов и есть Заголовок общий для всех страниц. Как мне проверить через match является ли текущая страница favorites, тоесть для /favorites/ /favorites/n и отобразить нужный класс?
render() {
        return (
            <Router>
                <div className="app">
                    <AppHeader/>
                    <Switch>
                        <Route exact path="/" component={NowPlayingPage}/>
                        <Route path="/page/:page" component={NowPlayingPage}/>
                        }}
                        />
                        <Route path="/movie/:id" component={MoviePage}/>
                        }}/>
                        <Route path="/favorites/:page?" component={FavoriteMoviePage}/>
                        }}/>
                        <Route component={Page404}/>
                    </Switch>
                </div>
                <AppFooter/>
            </Router>
        );
    }


Есть вот такой вариант, он рабочий но это костыль, хотелось бы но по нормальному средствами React.В консоли выводил match,location
match
{path: "/", url: "/", params: {…}, isExact: false}
isExact: false
params: {}
path: "/"
url: "/"

И в match не понимаю что из этого поможет мне выявить совпадение.

5dbc711198abd199193761.png

Возможно мне стоит вынести хедер в роут компоненты страниц и тогда match даст информацию, но это тоже странный вариант,то что можно вывести один раз в app выводить отдельно на каждой странице.
  • Вопрос задан
  • 1579 просмотров
Подписаться 1 Средний Комментировать
Пригласить эксперта
Ответы на вопрос 1
@akyl-kb
Просто используй Route
В AppHeader, в нужном месте
<Route path="/favorites" render={() =>
    <div>То что нужно показать если url == /favorites*</div>}>
Ответ написан
Комментировать
Ваш ответ на вопрос

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

Похожие вопросы