freeCodeCamp/guide/russian/react/react-router/index.md

63 lines
3.6 KiB
Markdown
Raw Normal View History

2018-10-19 12:53:51 +00:00
---
title: React Router
localeTitle: React Router
---
2018-10-19 12:53:51 +00:00
# React Router для начинающих
2018-10-12 20:00:59 +00:00
# Установка
2018-10-12 20:00:59 +00:00
React Router был разбит на три пакета: `react-router`, `react-router-dom` и `react-router-native`.
2018-10-12 20:00:59 +00:00
Вам почти никогда не придется устанавливать react-router напрямую. Этот пакет предоставляет основные компоненты и функции маршрутизации для приложений React Router. Другие два предоставляют специфические для среды (браузеры и реагирующие на) компоненты, но оба они также реэкспортируют все экспортные react-router.
Мы создаем веб-сайт (что-то, что будет запускаться в браузерах), поэтому мы нам надо установить response-router-dom.
2018-10-12 20:00:59 +00:00
`npm install --save react-router-dom`
# Маршрутизатор
При запуске нового проекта вам необходимо определить, какой тип маршрутизатора использовать. Для проектов на базе браузера есть также компоненты <BrowserRouter> и <HashRouter>. `<BrowserRouter>` вы должны использовать еслить у вас есть сервер с обработкой динамических запросов (знает как ответить на любой возможный URI), в то время как <HashRouter> должен использоваться для статических сайтов (где сервер может ответить только на запросы файлов о которых он знает).
Обычно рекомендуется использовать `<BrowserRouter>`, но если ваш сайт будет размещен на сервере, который обслуживает только статические файлы, то `<HashRouter>` является хорошим решением.
2018-10-12 20:00:59 +00:00
Для нашего проекта мы сделаем допущение, что веб-сайт поддерживаться динамическим сервером, поэтому нашим компонентом маршрутизатора будет является `<BrowserRouter>` .
2018-10-12 20:00:59 +00:00
# Импортирование
2018-10-12 20:00:59 +00:00
2018-10-12 20:00:59 +00:00
```javascript
2018-10-19 12:53:51 +00:00
import { BrowserRouter as Router, Switch, Route, Link } from 'react-router-dom';
2018-10-12 20:00:59 +00:00
```
## Компонент Link
2018-10-12 20:00:59 +00:00
Теперь давайте добавим навигацию, чтобы у нас получилось перемещаться между страницами.
2018-10-12 20:00:59 +00:00
Для этого мы будем использовать компонент `<Link>` . Использование компонента `<Link>` похоже на использование тегов ссылок в html.
2018-10-12 20:00:59 +00:00
Из официальной документации:
2018-10-12 20:00:59 +00:00
Основной способ реализации перемещения по вашему приложению. Компонент `<Link>` отрисовывает полностью рабочий тег ссылки, с соответствующим адресом href. Для начала создадим компонент Nav. Наш компонент Nav будет содержать компоненты `<Link>` и выглядит следующим образом:
2018-10-12 20:00:59 +00:00
2018-10-12 20:00:59 +00:00
```javascript
2018-10-19 12:53:51 +00:00
const Nav = () => (
<div>
<Link to='/'>Home</Link>&nbsp;
<Link to='/address'>Address</Link>
</div>
)
```