react-router-course-ru
  • Вступление
  • Подготовка
    • Настраиваем dev-окружение
  • Создаем примитивный роутер
  • Подключаем react-router
    • BrowserHistory vs HashHistory
    • Дописываем роуты
    • Активная ссылка
      • Ссылка на главную
    • IndexRedirect
    • Программируем переходы
    • Разделение доступа
    • Подтверждение перехода
    • Итого по роутингу
  • Подключаем redux
    • store.dispatch редирект
    • "Закрытый" компонент
    • Итого по react-router + redux
Powered by GitBook
On this page
  • Подключаем react-router
  • Задача
  • Решение

Was this helpful?

Подключаем react-router

PreviousСоздаем примитивный роутерNextBrowserHistory vs HashHistory

Last updated 5 years ago

Was this helpful?

ОБНОВЛЕНИЕ 2018: в учебнике хорошая теория, но ему уже два года. Проверяйте версии пакетов. За выходом нового учебника можно следить в или

На так же проводятся бесплатные вебинары, публикуются переводы и авторские материалы, !

Подключаем react-router

Продолжим разбирать страницу туториала.

Сейчас код компонента <App /> не выглядит слишком сложным. Но если развивать идею роутинга, появятся другие URL-адреса, что-то вложится во что-то большее... появится больше ссылок...

Скорее всего, нас ожидает трудноподдерживаемая путаница. Поэтому react-router с одной стороны можно рассматривать как "высокоуровневую" абстракцию, а с другой - полезный "плагин" с массой дополнительных плюшек. Давайте установим его и перепишем наш простой пример, который как обычно, в силу своей простоты, покажется несколько раздутым из-за использования react-router'а.

npm i react-router --save

src/index.js

import 'babel-polyfill'
import React from 'react'
import { render } from 'react-dom'
import App from './containers/App'
import Admin from './components/Admin'
import Genre from './components/Genre'
import Home from './components/Home'

import { Router, Route, IndexRoute, browserHistory } from 'react-router'

render(
  <Router history={browserHistory}>
    <Route path='/' component={App}>
      <IndexRoute component={Home} />
      <Route path='admin' component={Admin} />
      <Route path='genre' component={Genre} />
    </Route>
  </Router>,
  document.getElementById('root')
)

Так же, здесь мы использовали одну из главных фишек react-router'a - "вложения" (nesting). Мы вложили admin и genre в /, поэтому чтобы компоненты были доступны по соответствующим "урлам" (URL-адресам), осталось лишь выводить их как "потомков":

src/containers/App.js

import React, { Component } from 'react'
import { Link } from 'react-router'

export default class App extends Component {
  render() {
    return (
      <div className='container'>
        <h1>App</h1>
        <ul>
          <li><Link to='/admin'>Admin</Link></li>
          <li><Link to='/genre'>Genre</Link></li>
        </ul>
        {/* добавили вывод потомков */}
        {this.props.children}
      </div>
    )
  }
}

Согласно документации, мы также заменили <a></a> на компонент реакт-роутера - <Link />.

Код реакт-роутера хорошо читается и не изобилует новыми терминами. В следующей главе - продолжим настройку.

Итого: мы подключили react-router, посмотрели как назначается компонент на "корень" сайта, а так же познакомились с компонентом <Link />

Задача

Решение

...
render(
  <Router history={browserHistory}>
    <Route path='/' component={App}>
      <IndexRoute component={Home} />
      <Route path='admin' component={Admin}>
        <Route path='banlist' component={BanList} />
      </Route>
      <Route path='genre' component={Genre} />
    </Route>
  </Router>,
  document.getElementById('root')
)
...

Мы перенесли import компонентов в index.js, а ниже указали роуты. Обратите внимание, на <IndexRoute /> - так задается роут для "корня" (то есть для / , еще можно сказать - )

на данный момент.

Если бы у нас был компонент <BanList />, доступный по адресу: , как мог бы выглядеть роутер?

telegram канале
twitter
канале
присоединяйтесь
официального
http://localhost:3000
Исходный код
http://localhost:3000/admin/banlist