React Router v4 スタートガイド

May 26, 2018 pm 01:36 PM
react router ガイド

<p>この記事では主に React Router v4 エントリーガイド (概要) を紹介します。編集者が非常に優れていると考えたので、参考として共有します。編集者をフォローして見てみましょう

<p> React Router v4 が正式にリリースされてから 3 か月が経ちましたが、以前のルーティングはまだバージョン v2.7.0 を使用していたので、ルーティングもアップグレードすることにしました。アップグレードされました。ちょうど「何か新しいことを試す」のに間に合いました...

<p> 公式が 2.x と 4.x の 2 つのバージョンを同時に管理しているという噂があります。 (ヾ(。ꏿ﹏ꏿ)ノ゙ねえ、この時点で、私と同じくらい賢いあなたも気づくと思いますが、ReactRouter v3 はどこに行ったのでしょうか?すべて失ったでしょうか??Bala は問題を解決しました???完璧な説明をしていただけませんか?) 実際、バージョン 3.x にはバージョン 2.x と比べて新しい機能は導入されておらず、バージョン 2.x のいくつかの廃止された API の警告が削除されているだけです。計画によれば、歴史的な問題のない新しいプロジェクトが ReactRouter の安定版を使用したい場合は、ReactRouter 3.x を使用する必要があります。 3.x バージョンは現在まだベータ段階ですが、4.x バージョンよりも前に正式にリリースされる予定です。すでにバージョン 2.x を使用している場合は、3.x にアップグレードしても追加のコード変更は必要ありません。

<p>丁寧な紹介

<p> React Router V4 は、以前の 3 つのバージョンと比較して根本的な変更があります。まず、Just Component の API 設計コンセプトに従っています。第 2 に、API も大幅に合理化されています。初心者の学習の難しさは軽減されますが、以前のプロジェクトの再構築であれば、まあ、言うことはありません。このアップグレードの主な機能は次のとおりです:

  • <p>宣言型

  • <p>構成可能性

<p> React Router V4 は、React の哲学に従っています: すべてがコンポーネントです。したがって、アップグレードされるルート、リンク、スイッチなどはすべて共通のコンポーネントです。

<p>React Router V4 は、Lerna に基づいて複数のリポジトリを管理します。このコードベースに含まれるもの:

  1. <p>react-router React Router core

  2. <p>react-router-dom DOMバインディング用のReact Router

  3. <p>react-router-native React Native用のReact Router

  4. <p>react- router-redux React Router と Redux の統合

  5. <p>react-router-config 静的ルーティング設定ヘルパー

<p>プラグインの初期導入

<p>通常、React を使用するときは、通常、プラグインを導入する必要があります 2 つパッケージ、react および react-dom の場合、react-router および react-router-dom は使用しないでください。両方引用しますか? react 和  react-dom ,那么 react-routerreact-router-dom 是不是两个都要引用呢? 注意,前方高能,入门第一坑就在这里 。他们两个只要引用一个就行了,不同之处就是后者比前者多出了 <Link> <BrowserRouter> 这样的 DOM 类组件。因此我们只需引用 react-router-dom 这个包就OK了。当然,如果搭配 redux ,你还需要使用 react-router-redux

<p>主要组件简介

<p>在4.0之前版本的 API 中, <Router> 组件的 children 只能是 React Router 提供的各种组件,如 <Route>、<IndexRoute>、<Redirect> 等。而在 React Router 4 中,你可以将各种组件及标签放进 <Router> 组件中,他的角色也更像是 Redux 中的 <Provider> 。**不同的是 <Provider> 是用来保持与 store 的更新,而 <Router> 是用来保持与 location 的同步。**示例如下:

// 示例1
<Router>
 <p>
  <ul>
  <li><Link to="/">首页</Link></li>
  <li><Link to="/about">关于</Link></li>
  <li><Link to="/topics">主题列表</Link></li>
  </ul>

  <hr/>

  <Route exact path="/" component={Home}/>
  <Route path="/about" component={About}/>
  <Route path="/topics" component={Topics}/>
 </p>
 </Router>
ログイン後にコピー
<p>

<p>Router是所有路由组件共用的底层接口,一般我们的应用并不会使用这个接口,而是使用高级的路由:

  1. <p><BrowserRouter> :使用 HTML5 提供的 history API 来保持 UI 和 URL 的同步;

  2. <p><HashRouter> :使用 URL 的 hash (例如:window.location.hash) 来保持 UI 和 URL 的同步;

  3. <p><MemoryRouter> :能在内存保存你 “URL” 的历史纪录(并没有对地址栏读写);

  4. <p><NativeRouter> :为使用React Native提供路由支持;

  5. <p><StaticRouter> :从不会改变地址;

<p>TIPS:算是第二坑吧,和之前的Router不一样,这里 <Router> 组件下只允许存在一个子元素,如存在多个则会报错。

<p>反面典型在这里:

<Router>
  <ul>
  <li><Link to="/">首页</Link></li>
  <li><Link to="/about">关于</Link></li>
  <li><Link to="/topics">主题列表</Link></li>
  </ul>

  <hr/>

  <Route exact path="/" component={Home}/>
  <Route path="/about" component={About}/>
  <Route path="/topics" component={Topics}/>
 </Router>
ログイン後にコピー
<p>

<p>没错,示例2在没有 <p>注意、前方には高いエネルギーがあり、スタートする最初のピットはすぐそこです

。違いは、後者には前者よりも <Link><BrowserRouter> などの DOM クラス コンポーネントが多く含まれることです。したがって、react-router-dom パッケージを参照するだけで済みます。もちろん、redux と組み合わせる場合は、react-router-redux も使用する必要があります。 🎜🎜🎜主要コンポーネントの紹介🎜🎜🎜 4.0 より前の API バージョンでは、<Router> コンポーネントの子は、<Route&gt など、React Router によって提供されるさまざまなコンポーネントのみにすることができます。 ; 、<IndexRoute>、<Redirect> など。 React Router 4 では、さまざまなコンポーネントやタグを <Router> コンポーネントに入れることができ、その役割は Redux code> の <Provider> に似ています。 。 **違いは、<Provider> はストアとの最新情報を維持するために使用されるのに対し、<Router> は場所との同期を維持するために使用されることです。 **例は次のとおりです: 🎜

🎜

<Router>
 <p>
 <Route exact path="/" component={Home}/>
 <Route path="/news" component={NewsFeed}/>
 </p>
</Router>

// 如果应用的地址是/,那么相应的UI会类似这个样子:
<p>
 <Home/>
</p>

// 如果应用的地址是/news,那么相应的UI就会成为这个样子:
<p>
 <NewsFeed/>
</p>
ログイン後にコピー
ログイン後にコピー
🎜🎜🎜Router は、すべてのルーティング コンポーネントによって共有される基礎となるインターフェイスです。通常、アプリケーションはこのインターフェイスを使用しませんが、高度なルーティングを使用します。 🎜 🎜<BrowserRouter>: HTML5 が提供する履歴 API を使用して、UI と URL の同期を維持します。 🎜🎜🎜🎜<HashRouter>: のハッシュを使用します。 UI と URL の同期を保つための URL (例: window.location.hash) 🎜🎜🎜🎜<MemoryRouter>: 「URL」の履歴をメモリに保存できます。アドレス バーの書き込み) ;🎜🎜🎜🎜<NativeRouter> : React Native を使用するためのルーティング サポートを提供します 🎜🎜🎜🎜<StaticRouter> : アドレスを変更しません。 ; 🎜🎜🎜 🎜ヒント: これは 2 番目の落とし穴です。前の Router とは異なり、<Router> コンポーネントの下に子要素が 1 つだけ許可されている場合、エラーが発生します。報告。 🎜🎜否定的な例は次のとおりです: 🎜

🎜

// 行内渲染示例
<Route path="/home" render={() => <p>Home</p>}/>

// 包装/合成
const FadingRoute = ({ component: Component, ...rest }) => (
 <Route {...rest} render={props => (
 <FadeIn>
  <Component {...props}/>
 </FadeIn>
 )}/>
)

<FadingRoute path="/cool" component={Something}/>
ログイン後にコピー
ログイン後にコピー
🎜🎜🎜はい、例 2 は <p> の保護なしで次の例外メッセージを報告します: 🎜

<p>我们知道,Route组件主要的作用就是当一个location匹配路由的path时,渲染某些UI。示例如下:

<Router>
 <p>
 <Route exact path="/" component={Home}/>
 <Route path="/news" component={NewsFeed}/>
 </p>
</Router>

// 如果应用的地址是/,那么相应的UI会类似这个样子:
<p>
 <Home/>
</p>

// 如果应用的地址是/news,那么相应的UI就会成为这个样子:
<p>
 <NewsFeed/>
</p>
ログイン後にコピー
ログイン後にコピー
<p>

<p><Route> 组件有如下属性:

  1. <p>path(string): 路由匹配路径。(没有path属性的Route 总是会 匹配);

  2. <p>exact(bool):为true时,则要求路径与location.pathname必须完全匹配;

  3. <p>strict(bool):true的时候,有结尾斜线的路径只能匹配有斜线的location.pathname;

<p>再次奉上两个鲜活的例子:

<p>exact配置:

<p>

<p>

<p>


路径location.pathnameexact是否匹配
/one/one/twotrue
/one/one/twofalse
<p> strict配置:

<p>

路径location.pathnamestrict是否匹配
/one//onetrue
/one//one/true
/one//one/twotrue

同时,新版的路由为 <Route> 提供了三种渲染内容的方法:

  1. <p><Route component> :在地址匹配的时候React的组件才会被渲染,route props也会随着一起被渲染;

  2. <p><Route render> :这种方式对于内联渲染和包装组件却不引起意料之外的重新挂载特别方便;

  3. <p><Route children> :与render属性的工作方式基本一样,除了它是不管地址匹配与否都会被调用;

<p>第一种方式没啥可说的,和之前一样,这里我们重点看下 <Route render> 的渲染方式:

// 行内渲染示例
<Route path="/home" render={() => <p>Home</p>}/>

// 包装/合成
const FadingRoute = ({ component: Component, ...rest }) => (
 <Route {...rest} render={props => (
 <FadeIn>
  <Component {...props}/>
 </FadeIn>
 )}/>
)

<FadingRoute path="/cool" component={Something}/>
ログイン後にコピー
ログイン後にコピー
<p>

<p>TIPS: 第三坑! <Route component> 的优先级要比 <Route render> 高,所以不要在同一个 <Route> 中同时使用这两个属性。

<p>和之前版本没太大区别,重点看下组件属性:

  1. <p>to(string/object):要跳转的路径或地址;

  2. <p>replace(bool): 为 true 时 ,点击链接后将使用新地址替换掉访问历史记录里面的原地址; 为 false 时 ,点击链接后将在原有访问历史记录的基础上添加一个新的纪录。 默认为 false

<p>示例如下:

// Link组件示例

// to为string
<Link to="/about">关于</Link>

// to为obj
<Link to={{
 pathname: &#39;/courses&#39;,
 search: &#39;?sort=name&#39;,
 hash: &#39;#the-hash&#39;,
 state: { fromDashboard: true }
}}/>

// replace 
<Link to="/courses" replace />
ログイン後にコピー
<p>

<p><NavLink><Link> 的一个特定版本, 会在匹配上当前 URL 的时候会给已经渲染的元素添加样式参数,组件属性:

  1. <p>activeClassName(string):设置选中样式,默认值为 active;

  2. <p>activeStyle(object):当元素被选中时, 为此元素添加样式;

  3. <p>exact(bool):为 true 时, 只有当地址完全匹配 class 和 style 才会应用;

  4. <p>strict(bool):为 true 时,在确定位置是否与当前 URL 匹配时,将考虑位置 pathname 后的斜线; isActive(func):判断链接是否激活的额外逻辑的功能;

<p>从这里我们也可以看出,新版本的路由在组件化上面确实下了不少功夫,来看看NavLink的使用示例:

<p>

// activeClassName选中时样式为selected
<NavLink
 to="/faq"
 activeClassName="selected"
>FAQs</NavLink>

// 选中时样式为activeStyle的样式设置
<NavLink
 to="/faq"
 activeStyle={{
 fontWeight: &#39;bold&#39;,
 color: &#39;red&#39;
 }}
>FAQs</NavLink>

// 当event id为奇数的时候,激活链接
const oddEvent = (match, location) => {
 if (!match) {
 return false
 }
 const eventID = parseInt(match.params.eventID)
 return !isNaN(eventID) && eventID % 2 === 1
}

<NavLink
 to="/events/123"
 isActive={oddEvent}
>Event 123</NavLink>
ログイン後にコピー
<p>

<p>该组件用来渲染匹配地址的第一个 <Route> 或者 <Redirect> 。那么它与使用一堆route又有什么区别呢?

<p><Switch> 的独特之处是独它仅仅渲染一个路由。相反地,每一个包含匹配地址(location)的 <Route> 都会被渲染。思考下面的代码:

<Route path="/about" component={About}/>
<Route path="/:user" component={User}/>
<Route component={NoMatch}/>
ログイン後にコピー
<p>

<p>如果现在的URL是 /about ,那么 <About> , <User> , 还有 <NoMatch> 都会被渲染,因为它们都与路径(path)匹配。这种设计,允许我们以多种方式将多个 <Route> 组合到我们的应用程序中,例如侧栏(sidebars),面包屑(breadcrumbs),bootstrap tabs等等。 然而,偶尔我们只想选择一个 <Route> 来渲染。如果我们现在处于 /about ,我们也不希望匹配 /:user (或者显示我们的 “404” 页面 )。以下是使用 Switch 的方法来实现:

<Switch>
 <Route exact path="/" component={Home}/>
 <Route path="/about" component={About}/>
 <Route path="/:user" component={User}/>
 <Route component={NoMatch}/>
</Switch>
ログイン後にコピー
<p>

<p>现在,如果我们处于 /about<Switch> 将开始寻找匹配的 <Route><Route path="/about"/> 将被匹配, <Switch> 将停止寻找匹配并渲染 <About> 。同样,如果我们处于 /michael<User> 将被渲染。

<p>上面是我整理给大家的,希望今后会对大家有帮助。

<p>相关文章:

<p>AJAX封装类使用指南

<p>Ajax中浏览器和服务器交互详解

<p>AJAX初级教程之初识AJAX

<p>

以上がReact Router v4 スタートガイドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Windows 11 で VBS をオフにするガイド Windows 11 で VBS をオフにするガイド Mar 08, 2024 pm 01:03 PM

Windows 11 のリリースに伴い、Microsoft は VBS (仮想化ベースのセキュリティ) と呼ばれるセキュリティ機能を含む、いくつかの新機能と更新プログラムを導入しました。 VBS は仮想化テクノロジーを利用してオペレーティング システムと機密データを保護し、それによってシステムのセキュリティを向上させます。ただし、一部のユーザーにとって、VBS は必要な機能ではなく、システムのパフォーマンスに影響を与える場合もあります。したがって、この記事では、Windows 11でVBSをオフにする方法を紹介します。

VSCode を使用した中国語のセットアップ: 完全ガイド VSCode を使用した中国語のセットアップ: 完全ガイド Mar 25, 2024 am 11:18 AM

中国語での VSCode セットアップ: 完全ガイド ソフトウェア開発では、Visual Studio Code (略して VSCode) が一般的に使用される統合開発環境です。中国語を使用する開発者は、VSCode を中国語インターフェイスに設定すると、作業効率が向上します。この記事では、VSCode を中国語インターフェイスに設定する方法を詳しく説明し、具体的なコード例を示す完全なガイドを提供します。ステップ 1: 言語パックをダウンロードしてインストールします。VSCode を開いた後、左側の

jQueryのリファレンスメソッドを詳しく解説:クイックスタートガイド jQueryのリファレンスメソッドを詳しく解説:クイックスタートガイド Feb 27, 2024 pm 06:45 PM

jQuery 参照方法の詳細説明: クイック スタート ガイド jQuery は、Web サイト開発で広く使用されている人気のある JavaScript ライブラリであり、JavaScript プログラミングを簡素化し、開発者に豊富な機能を提供します。この記事では、jQuery の参照方法を詳しく紹介し、読者がすぐに使い始めるのに役立つ具体的なコード例を示します。 jQuery の導入 まず、HTML ファイルに jQuery ライブラリを導入する必要があります。 CDN リンクを通じて導入することも、ダウンロードすることもできます

Deepin Linux をタブレットにインストールします。 Deepin Linux をタブレットにインストールします。 Feb 13, 2024 pm 11:18 PM

Linux オペレーティング システムは技術の継続的な発展に伴い、さまざまな分野で広く使用されています. Deepin Linux システムをタブレットにインストールすることで、より便利に Linux の魅力を体験することができます. タブレットへの Deepin Linux のインストールについて説明します. Linux の具体的な手順について説明します.準備作業 Deepin Linux をタブレットにインストールする前に、いくつかの準備をする必要があります。インストールプロセス中のデータ損失を避けるために、タブレット内の重要なデータをバックアップする必要があります。Deepin Linux のイメージ ファイルをダウンロードして、次の場所に書き込む必要があります。インストールプロセス中に使用するために、USB フラッシュドライブまたは SD カードに保存します。次に、インストールプロセスを開始できます.UディスクまたはSDから起動するようにタブレットを設定する必要があります

Conda 使用ガイド: Python バージョンを簡単にアップグレードする Conda 使用ガイド: Python バージョンを簡単にアップグレードする Feb 22, 2024 pm 01:00 PM

Conda 使用ガイド: Python バージョンを簡単にアップグレードします。特定のコード例が必要です。 はじめに: Python の開発プロセス中、新機能を入手したり、既知のバグを修正したりするために、Python バージョンをアップグレードする必要があることがよくあります。ただし、特にプロジェクトや依存パッケージが比較的複雑な場合、Python バージョンを手動でアップグレードするのは面倒な場合があります。幸いなことに、Conda は優れたパッケージ マネージャーおよび環境管理ツールとして、Python バージョンを簡単にアップグレードするのに役立ちます。この記事では使い方を紹介します

PHP、Vue、React: 最適なフロントエンド フレームワークを選択するには? PHP、Vue、React: 最適なフロントエンド フレームワークを選択するには? Mar 15, 2024 pm 05:48 PM

PHP、Vue、React: 最適なフロントエンド フレームワークを選択するには?インターネット技術の継続的な発展に伴い、フロントエンド フレームワークは Web 開発において重要な役割を果たしています。 PHP、Vue、React は 3 つの代表的なフロントエンド フレームワークであり、それぞれに独自の特徴と利点があります。使用するフロントエンド フレームワークを選択するとき、開発者はプロジェクトのニーズ、チームのスキル、個人の好みに基づいて情報に基づいた決定を下す必要があります。この記事では、PHP、Vue、React の 3 つのフロントエンド フレームワークの特徴と用途を比較します。

Java フレームワークとフロントエンド React フレームワークの統合 Java フレームワークとフロントエンド React フレームワークの統合 Jun 01, 2024 pm 03:16 PM

Java フレームワークと React フレームワークの統合: 手順: バックエンド Java フレームワークをセットアップします。プロジェクト構造を作成します。ビルドツールを設定します。 React アプリケーションを作成します。 REST API エンドポイントを作成します。通信メカニズムを構成します。実際のケース (SpringBoot+React): Java コード: RESTfulAPI コントローラーを定義します。 React コード: API によって返されたデータを取得して表示します。

PHP7 インストールディレクトリ構成ガイド PHP7 インストールディレクトリ構成ガイド Mar 11, 2024 pm 12:18 PM

PHP7 インストール ディレクトリ構成ガイド PHP は、動的 Web ページの開発に使用される一般的なサーバー側スクリプト言語です。現在、PHP の最新バージョンは PHP7 です。これには、多くの新機能とパフォーマンスの最適化が導入されており、多くの Web サイトやアプリケーションで推奨されるバージョンです。 PHP7 をインストールするときは、インストール ディレクトリを正しく構成することが非常に重要です。この記事では、具体的なコード例とともに、PHP7 のインストール ディレクトリを構成するための詳細なガイドを提供します。まず PHP7 をダウンロードするには、PHP 公式 Web サイト (https://www.

See all articles