自動化無しに生活無し

WEB開発関係を中心に備忘録をまとめています

react-router-domの使い方【Reactでルーティング】

thumbnail

ページが複数あるサイトをReactで作る場合、react-router-domでルーティングを行うと良いだろう。

npm install react-router-dom

使い方

コンポーネントを作る

src/components/に以下ファイルを配置。

Home.jsx
Portfolio.jsx
Profile.jsx  

Home.jsx

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

export const Home = () => {
    return (
        <>

        <div>ここはホームです</div>

        <Link to={`/portfolio`}>ポートフォリオ</Link>
        <Link to={`/profile`}>プロフィール</Link>

        </>
    );
}

Portfolio.jsx

export const Portfolio = () => {
    return (
        <>
        <div>ここはポートフォリオです</div>
        </>
    );
}

Profile.jsx

export const Profile = () => {
    return (
        <>
        <div>ここはプロフィール</div>
        </>
    );
}

src/App.jsx から呼び出す

Home.jsx, Portfolio.jsx, Profile.jsxを呼び出す。

import {BrowserRouter, Routes, Route} from 'react-router-dom';

import { Home } from "./components/Home";
import { Portfolio } from "./components/Portfolio";
import { Profile } from "./components/Profile";

import "./App.css"


export const App = () => {
    return (
        <>
        <a href="/">
            <h1>Myportfolio</h1>
        </a>

        <BrowserRouter>
            <Routes>
                <Route path={`/`}           element={<Home />} />
                <Route path={`/portfolio/`} element={<Portfolio />} />
                <Route path={`/profile/`}   element={<Profile />} />
            </Routes>
        </BrowserRouter>

        <div className="link_area">
            <a className="link" href="/portfolio">ポートフォリオ</a>
            <a className="link" href="/profile">プロフィール</a>
        </div>


        </>

    );
}

ここでreact-router-domからBrowserRouter 及び RoutesRouteをimportする。

結論

BrowserRouterとRoutesの違いがよくわからない。BrowserRouterを書かないサイトも見受けられる。こちらは調査した後、追記する予定。

また、現行バージョン(V6)とかつてのバージョン(V5以前)の記法がネット上で混在しているので注意。

参照元

ソースコード : https://github.com/seiya0723/react-router-test

スポンサーリンク