TECH I.S.

React ルーター


Create 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フォルダー内に、いくつかのファイルを含むpage という名前のフォルダーを作成します。 src\pages\:
  • Layout.js
  • Home.js
  • Blogs.js
  • Contact.js
  • NoPage.js

各ファイルには、非常に基本的なReactコンポーネントが含まれます。


基本的な使い方

次に、index.jsファイルでRouterを使用します。

React Routerを使用して、URLに基づいてページにルーティングします。 index.js:
importReactDOMfrom"react-dom/client"; import { BrowserRouter, Routes, Route } from"react-router-dom"; importLayoutfrom"./pages/Layout"; importHomefrom"./pages/Home"; importBlogsfrom"./pages/Blogs"; importContactfrom"./pages/Contact"; importNoPagefrom"./pages/NoPage"; exportdefaultfunctionApp() {   return (     <BrowserRouter>       <Routes>         <Routepath="/"element={<Layout />}>           <Routeindexelement={<Home />} />           <Routepath="blogs"element={<Blogs />} />           <Routepath="contact"element={<Contact />} />           <Routepath="*"element={<NoPage />} />         </Route>       </Routes>     </BrowserRouter>   ); } const root = ReactDOM.createRoot(document.getElementById('root')); root.render(<App />);

実行例(開発準備中) »

例の説明

まずコンテンツを<BrowserRouter>でラップします。

次に、<Routes>を定義します。アプリケーションは複数の<Routes>を持つことができます。この基本的な例では1つだけを使用します。

<Route>はネストできます。最初の<Route>には/のパスがあり、Layoutコンポーネントをレンダリングします。

ネストされた<Route>は親ルートを継承し、親ルートに追加します。したがって、blogsパスは親と結合されて、/blogsになります。

Homeコンポーネントのルートにはパスはありませんが、index属性があります。これにより、このルートが親ルート(/)のデフォルトルートとして指定されます。 path*に設定すると、未定義のURLのキャッチオールとして機能します。これは404エラーページに最適です。

ページ/コンポーネント

Layoutコンポーネントには<Outlet>要素と <Link>要素があります。 <Outlet>は、選択されている現在のルートをレンダリングします。 <Link>は、URLを設定し、閲覧履歴を追跡するために使用されます。

内部パスにリンクする場合は常に、<a href="">の代わりに<Link>を使用します。

「レイアウトルート」は、ナビゲーションメニューなど、すべてのページに共通のコンテンツを挿入する共有コンポーネントです。

Layout.js:
import { Outlet, Link } from"react-router-dom"; constLayout = () => {   return (     <>       <nav>         <ul>           <li>             <Linkto="/">Home</Link>           </li>           <li>             <Linkto="/blogs">Blogs</Link>           </li>           <li>             <Linkto="/contact">Contact</Link>           </li>         </ul>       </nav>       <Outlet />     </>   ) }; exportdefaultLayout;
Home.js:
constHome = () => {   return<h1>Home</h1>; }; exportdefaultHome;
Blogs.js:
constBlogs = () => {   return<h1>Blog Articles</h1>; }; exportdefaultBlogs;
Contact.js:
constContact = () => {   return<h1>Contact Me</h1>; }; exportdefaultContact;
NoPage.js:
constNoPage = () => {   return<h1>404</h1>; }; exportdefaultNoPage;


プログラミング学習を加速させる

プログラミングをプロの講師に教えてもらいませんか。

テックアイエスのプログラミングスクールは初心者も大歓迎です。年齢制限もありません。転職・副業に強く、挫折させない手厚いサポートで稼ぐ力を身につけましょう!

スクールの詳細