React система роутингу.

Фронтенд розробка JavaScript. -> React система роутинга.

Роутінг у реакті.

Додамо бібліотеку історії.

Посилання на доку

npm install history @types/history --save

Додамо імпорт до index.js

import {createBrowserHistory} from 'history';

ReactDOM.render(
  <React.StrictMode>
    <App />
  </React.StrictMode>,
  document.getElementById('root')
);

Бібліотека react-router

посилання на джерело

Ми будемо створювати сайт, який буде відображатися в браузері, тому нам слід використовувати react-router-dom. react-router-dom експортує з react-router всі функції, тому нам можна встановити тільки react-router-dom.

Встановлення.

npm install react-router @types/react-router --save
npm install react-router-dom @types/react-router-dom --save

посилання на документацію

Бібліотека надає такі компоненти:

Навігація по кліку (компонент )

Перенаправлення (компонент )

Маршрутизація (компонент Route)

Загортаємо додаток у компонент роутера.

// імпорт компонента роутера
import { BrowserRouter } from 'react-router-dom';

ReactDOM.render(
  <React.StrictMode>
    <BrowserRouter>
      <App />
    </BrowserRouter>
  </React.StrictMode>,
  document.getElementById('root')
);

Якщо з’являється така помилка

Start page

Це відбувається через порядок імпорту, необхідно підняти якомога вище за кодом імпорт.

// імпорт компонента роутера
import { Router } from "react-router-dom"
import {createBrowserHistory} from 'history';

Розділимо додаток на ldf компонент Head і Main

import Header from './Header';
import Main from './Main';

function App(props: any) {

  return (
    <div className="App">
      <Header />
      <Main />
    </div>
  );
}

export default App;

Створимо компоненти сторінок Home та Chat

pages/Chat.tsx

import React from 'react';

function Chat(props: any) {


    return (
      <div className="Home">
          <h1>Chat component</h1>
      </div>
    );
  }

export default Chat;

pages/Home.tsx

import React from 'react';

function Home(props: any) {


    return (
      <div className="Home">
          <h1>Home component</h1>
      </div>
    );
  }

export default Home;

У Main визначимо маршрути.

import React from 'react';
import { Switch, Route, Redirect } from 'react-router-dom';

import Home from './pages/Home';
import Chat from './pages/Chat';

function Main(props: any) {


    return (
      <div className="Header">

          <h1>Main component</h1>
          <Switch>
            <Route exact path='/home' component={Home}/>
            <Route path='/chat' component={Chat}/>
            <Redirect from='/' to='/home'/>
            </Switch>
      </div>
    );
  }

export default Main;

Залишилося створити посилання в Head компоненті.

import React from 'react';
import { Link } from "react-router-dom";
function Header(props: any) {


    return (
      <div className="Header">
            <Link className='SectionNavigation-Item Section' to='/home'>
                        Home
            </Link>
            <Link className='SectionNavigation-Item Section' to='/chat'>
                        Chat
            </Link>
      </div>
    );
  }

export default Header;

У пропси компонента маршрутизатор закидає 3 об’єкти.

console.log(props);

Start page

Дочірній роутинг.

import ChatMain from './ChatMain';
import ChatRoom from './ChatRoom';
import { Link } from "react-router-dom";

function Chat(props: any) {


    return (
      <div className="Home">
          <h1>Chat component</h1>
          <Link className='SectionNavigation-Item Section' to='/chat/main'>
                        Main
            </Link>
            <Link className='SectionNavigation-Item Section' to='/chat/room/3'>
                        Room
            </Link>
          <Switch>
            <Route exact path='/chat/main' component={ChatMain}/>
            <Route path='/chat/room/:number' component={ChatRoom}/>
            <Redirect from='/chat' to='/chat/main'/>
        </Switch>
      </div>
    );
  }

Параметри роутингу.

Параметри можна отримувати з пропсів компонента, що прив’язаний до роуту з параметром.

Start page