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

Как правильно настроить роутинг в React router v6?

Всем доброго дня.
Коллеги, как правильно выполнить настройку роутинга, если необходимо перенаправлять пользователя в личный кабинет в зависимости от его статуса?

Т.е. в приложении есть не авторизированный пользователь, есть админ и есть простой авторизированный пользователь. пока тренируюсь на локале, по этому просто по клику на кнопку меняю поле auth объекта isAuth на true и ставлю в поле user статус admin или user.

Вот так выглядит роутинг:

const Navigation = () => {

    const {isAuth} = useContext(AuthContext)
  return (
    
      
        isAuth.auth
        ?
          isAuth.user === 'admin' 
          ?
          <Routes>
          <Route path="/admin/*" element={<AdminCabinet />} />
          <Route path='*' element={<Navigate replace to="/admin" />}/>
        </Routes>
          :
          <Routes>
          <Route path="/lk" element={<UserCabinet />} />
          <Route path='*' element={<Navigate replace to="/lk" />}/>
        </Routes>
        :
        <Routes>
          <Route path="/" element={<MainPage />} />
          <Route path='*' element={<Navigate replace to="/" />}/>
        </Routes>
    );
};


Когда нажимаю вход все работает, в личные кабинеты система заходит. Но, если выйти из кабинетов и потом обновить страницу, то мы попадает по пути /lk. Хотя isAuth в это время стоит false. Как я понимаю, тернарный оператор нельзя так использовать. Но как тогда корректно отследить несколько состояний, если надо из 3 различных роутов выбирать? И как правильно сделать роутинг между админом, пользователем и не зарегистрированным человеком, если им всем разные страницы надо показывать?
  • Вопрос задан
  • 180 просмотров
Подписаться 1 Простой Комментировать
Помогут разобраться в теме Все курсы
  • Яндекс Практикум
    React-разработчик
    3 месяца
    Далее
  • Merion Academy
    Frontend-разработка на React
    4 месяца
    Далее
  • ProductStar
    React: отточите навыки интерфейсной разработки
    6 недель
    Далее
Пригласить эксперта
Ответы на вопрос 1
Вы не совсем правильно понимаете что такое Route. Он представляет собой просто if-then, который определяет, какой элемент нужно отрендерить в зависимости от пути в адресной строки. Перенаправления он не выполняет. Чтобы перенаправить пользователя, нужно при определенных условиях отрендерить Navigate
Ответ написан
Ваш ответ на вопрос

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

Похожие вопросы
ITK academy Нижний Новгород
от 50 000 до 90 000 ₽
IT ATLAS Москва
от 200 000 до 250 000 ₽
ITK academy Казань
от 50 000 до 90 000 ₽