НАЙКРАЩИЙ САЙТ ДЛЯ ВЕБ-РОЗРОБНИКІВ
React. W3Schools українською. Уроки для початківців

En

React Роутер (Маршрутизатор)


Створення React App не включає маршрутизацію сторінок.

React Router є найпопулярнішим рішенням.


Додати маршрутизатор React

Щоб додати React Router у свою програму, запустіть це в терміналі з кореневого каталогу програми:

npm i -D react-router-dom

Примітка: У цьому посібнику використовується React Router v6.

Якщо ви оновлюєтеся з v5, вам потрібно буде використовувати позначку @latest:

npm i -D react-router-dom@latest

Структура папки

Щоб створити програму з кількома маршрутами сторінок, давайте спочатку почнемо зі структури файлу.

У папці src ми створимо папку під назвою pages з кількома файлами:

src\pages\:

  • Layout.js
  • Home.js
  • Blogs.js
  • Contact.js
  • NoPage.js

Кожен файл міститиме базовий компонент React.


Основне використання

Тепер ми використаємо маршрутизатор у нашому файлі index.js.

Приклад

Використовуйте React Router для маршрутизації до сторінок на основі URL-адреси:

index.js:

import ReactDOM from "react-dom/client";
import { BrowserRouter, Routes, Route } from "react-router-dom";
import Layout from "./pages/Layout";
import Home from "./pages/Home";
import Blogs from "./pages/Blogs";
import Contact from "./pages/Contact";
import NoPage from "./pages/NoPage";

export default function App() {
return (
<BrowserRouter>
  <Routes>
    <Route path="/" element={<Layout />}>
      <Route index element={<Home />} />
      <Route path="blogs" element={<Blogs />} />
      <Route path="contact" element={<Contact />} />
      <Route path="*" element={<NoPage />} />
    </Route>
  </Routes>
</BrowserRouter>
);
}

const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<App />);

Виконати приклад »

Пояснення прикладу

Спочатку ми обертаємо наш вміст <BrowserRouter>.

Тоді ми визначаємо наш <Routes>. Додаток може мати кілька <Routes>. У нашому базовому прикладі використовується лише один.

<Route> можуть бути вкладеними. Перший <Route> має шлях / і відображає компонент Layout.

Вкладені <Route> успадковують і додають до батьківського маршруту. Тож шлях blogs поєднується з батьківським і стає /blogs.

Маршрут компонента Home не має шляху, але має атрибут index Це визначає цей маршрут як маршрут за замовчуванням для батьківського маршруту, яким є /.

Встановлення для path значення * діятиме як універсальне для всіх невизначених URL-адрес. Це підходить для сторінки помилки 404.


Сторінки / Компоненти

Компонент Layout має <Outlet> і елементи <Link>.

<Outlet> відображає поточний вибраний маршрут.

<Link> використовується для встановлення URL-адреси та відстеження історії веб-перегляду.

Щоразу, коли ми посилаємося на внутрішній шлях, ми використовуватимемо <Link> замість <a href="">.

"Маршрут макета" – це спільний компонент, який вставляє загальний вміст на всі сторінки, як-от навігаційне меню.

Layout.js:

import { Outlet, Link } from "react-router-dom";

const Layout = () => {
return (
<>
  <nav>
    <ul>
      <li>
        <Link to="/">Home</Link>
      </li>
      <li>
        <Link to="/blogs">Blogs</Link>
      </li>
      <li>
        <Link to="/contact">Contact</Link>
      </li>
    </ul>
  </nav>

  <Outlet />
</>
)
};

export default Layout;

Home.js:

const Home = () => {
return <h1>Home</h1>;
};

export default Home;

Blogs.js:

const Blogs = () => {
return <h1>Blog Articles</h1>;
};

export default Blogs;

Contact.js:

const Contact = () => {
return <h1>Contact Me</h1>;
};

export default Contact;

NoPage.js:

const NoPage = () => {
return <h1>404</h1>;
};

export default NoPage;