Abr_ya
@Abr_ya

React Router — разное поведение dev и build — как исправить?

Есть проблема с пониманием работы React Router.
Я сделал приложение, которое использует git API, выводит информацию о пользователях и репозиториях.
Использую роутер.
Т.к. на хостинг выкладываю не в корень, а в подкаталог, в роутере добавил:
basename="/demo/git2/"
При запуске рабочего варианта (npm start) работает навигация и страницы открываются по прямой ссылке, в т.ч. страницы отдельных пользователей (если скопировать и вставить в адресную строку).
При сборке (build) и размещении на сервере
abr-just.ru/demo/git2
навигация по ссылкам работает:
5efa3427c29dd865979087.jpeg
но по прямой ссылке не открывается даже страница "about":
5efa342dcde96864329606.jpeg
Ещё наглядное проявление бага: если в результате поиска перейти на страницу пользователя, потом поставить курсор в адресную строку и нажать Enter, в результате также NotFound.
Вопрос: что я делаю не так и как это исправить?
  • Вопрос задан
  • 80 просмотров
Решения вопроса 1
@McBernar
Вам нужно, чтобы сервер направлял все запросы на индексный файл. Когда вы заходите на главную — сервер находит ее, потому что там есть index.html. Когда вы переходите по ссылкам — реакт трекает это и рендерит нужные страницы. Но как только вы пытаетесь открыть что-то напрямую — сервер просто не находит вашего about.html.

Гуглите «htaccess перенаправление на индекс»

Ладно, не гуглите, вот

RewriteEngine on
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /index.html [L]
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

Войти через центр авторизации
Похожие вопросы