0

0

实习生级别:使用 React Router 进行路由

WBOY

WBOY

发布时间:2024-07-18 09:16:19

|

576人浏览过

|

来源于dev.to

转载

实习生级别:使用 react router 进行路由

路由是构建现代 web 应用程序的一个关键方面。 react router 是一个功能强大的库,允许您在 react 应用程序中处理路由。本指南将向您介绍 react router,涵盖基本设置和使用,以及高级路由技术和路由防护。

react 路由器简介

react router 可以在 react 应用程序中的不同组件之间进行导航,允许您创建具有多个视图的单页面应用程序。

设置 react 路由器

要开始使用 react router,您需要将其安装到您的项目中。您可以使用 npm 或yarn 来完成此操作。

npm install react-router-dom


yarn add react-router-dom

路由、交换机、链接和 navlink 组件

react router 提供了几个组件来定义路由和处理导航。

路线组件

route 组件用于在应用程序中定义路由。它指定了路径以及路径匹配时应该渲染的组件。

示例:

import react from 'react';
import { browserrouter as router, route } from 'react-router-dom';
import home from './home';
import about from './about';

const app = () => {
  return (
    
      
      
    
  );
};

export default app;

本例中,当路径为 / 时会渲染 home 组件,当路径为 /about 时会渲染 about 组件。

开关元件

switch 组件确保一次只渲染一条路线。它渲染与当前 url 匹配的第一个 route。

示例:

import react from 'react';
import { browserrouter as router, route, switch } from 'react-router-dom';
import home from './home';
import about from './about';
import notfound from './notfound';

const app = () => {
  return (
    
      
        
        
        
      
    
  );
};

export default app;

在本例中,如果没有路由匹配,将渲染 notfound 组件。

链接组件

link 组件用于在应用程序中创建导航链接。它的工作原理与锚点 () 标签类似,但可以避免整个页面重新加载。

示例:

import react from 'react';
import { browserrouter as router, route, link } from 'react-router-dom';
import home from './home';
import about from './about';

const app = () => {
  return (
    
      
      
      
    
  );
};

export default app;

在此示例中,单击链接将导航到相应的路线,而无需重新加载页面。

导航链接组件

navlink 组件与 link 组件类似,但提供了基于活动路线的附加样式功能。

示例:

import react from 'react';
import { browserrouter as router, route, navlink } from 'react-router-dom';
import home from './home';
import about from './about';

const app = () => {
  return (
    
      
      
      
    
  );
};

export default app;

在此示例中,activeclassname 属性用于将活动类应用到与当前路由匹配的链接。

先进的路由技术

嵌套路由

嵌套路由允许您在其他路由中创建路由。这对于创建带有子导航的布局很有用。

WeShop唯象
WeShop唯象

WeShop唯象是国内首款AI商拍工具,专注电商产品图片的智能生成。

下载

示例:

import react from 'react';
import { browserrouter as router, route, switch, link, useroutematch } from 'react-router-dom';

const topic = ({ match }) => 

requested topic id: {match.params.topicid}

; const topics = () => { let { path, url } = useroutematch(); return (

topics

  • components
  • props v. state

please select a topic.

); }; const app = () => (
  • home
  • topics

home

); export default app;

在此示例中,主题组件包含嵌套路由,允许主题部分内的子导航系统。

动态路由

动态路由允许您基于动态参数创建路由,例如用户 id 或产品 id。

示例:

import react from 'react';
import { browserrouter as router, route, switch, link } from 'react-router-dom';

const user = ({ match }) => 

user id: {match.params.userid}

; const app = () => (
  • user 1
  • user 2
); export default app;

在此示例中,用户组件使用作为路由参数传递的用户 id 进行渲染。

路由参数

路由参数允许您从 url 捕获值并在组件中使用它们。

示例:

import react from 'react';
import { browserrouter as router, route, switch, link } from 'react-router-dom';

const product = ({ match }) => 

product id: {match.params.productid}

; const app = () => (
  • product 101
  • product 202
); export default app;

在本例中,product组件使用productid路由参数来显示产品id。

路由守卫和重定向

路由防护和重定向可帮助您根据条件(例如用户身份验证)控制对某些路由的访问。

保护路线

为了保护路由,您可以创建一个高阶组件(hoc),在渲染组件之前检查条件(例如,用户身份验证)。

示例:

import react from 'react';
import { browserrouter as router, route, redirect } from 'react-router-dom';

const isauthenticated = false;

const privateroute = ({ component: component, ...rest }) => (
  
      isauthenticated ?  : 
    }
  />
);

const dashboard = () => 

dashboard

; const login = () =>

login

; const app = () => (
); export default app;

在此示例中,privateroute 组件在渲染 dashboard 组件之前检查用户是否经过身份验证。如果用户未通过身份验证,他们将被重定向到登录组件。

在 react router 中实现重定向

可以使用重定向组件来实现重定向,以编程方式将用户导航到不同的路线。

示例:

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

const OldPage = () => 

Old Page (will redirect)

; const NewPage = () =>

New Page

; const App = () => ( ); export default App;

在此示例中,访问 /old-page 将自动将用户重定向到 /new-page。

结论

理解和使用 react router 实现路由对于构建健壮的 react 应用程序至关重要。通过掌握设置路由、使用 link 和 navlink 处理导航的基础知识,以及实现嵌套路由、动态路由、路由参数和路由防护等高级技术,您可以在应用程序中创建无缝且安全的导航体验。随着您不断发展自己的技能,这些概念将成为您使用 react 构建复杂的单页应用程序的能力的基础。

路由优化大师
路由优化大师

路由优化大师是一款及简单的路由器设置管理软件,其主要功能是一键设置优化路由、屏广告、防蹭网、路由器全面检测及高级设置等,有需要的小伙伴快来保存下载体验吧!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
switch语句用法
switch语句用法

switch语句用法:1、Switch语句只能用于整数类型,枚举类型和String类型,不能用于浮点数类型和布尔类型;2、每个case语句后面必须跟着一个break语句,以防止执行其他case的代码块,没有break语句,将会继续执行下一个case的代码块;3、可以在一个case语句中匹配多个值,使用逗号分隔;4、Switch语句中的default代码块是可选的等等。

534

2023.09.21

Java switch的用法
Java switch的用法

Java中的switch语句用于根据不同的条件执行不同的代码块。想了解更多switch的相关内容,可以阅读本专题下面的文章。

417

2024.03.13

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

3

2026.01.21

无人机驾驶证报考 uom民用无人机综合管理平台官网
无人机驾驶证报考 uom民用无人机综合管理平台官网

无人机驾驶证(CAAC执照)报考需年满16周岁,初中以上学历,身体健康(矫正视力1.0以上,无严重疾病),且无犯罪记录。个人需通过民航局授权的训练机构报名,经理论(法规、原理)、模拟飞行、实操(GPS/姿态模式)及地面站训练后考试合格,通常15-25天拿证。

14

2026.01.21

Python多线程合集
Python多线程合集

本专题整合了Python多线程相关教程,阅读专题下面的文章了解更多详细内容。

1

2026.01.21

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

3

2026.01.21

windows激活码分享 windows一键激活教程指南
windows激活码分享 windows一键激活教程指南

Windows 10/11一键激活可以通过PowerShell脚本或KMS工具实现永久或长期激活。最推荐的简便方法是打开PowerShell(管理员),运行 irm https://get.activated.win | iex 脚本,按提示选择数字激活(选项1)。其他方法包括使用HEU KMS Activator工具进行智能激活。

2

2026.01.21

excel表格操作技巧大全 表格制作excel教程
excel表格操作技巧大全 表格制作excel教程

Excel表格操作的核心技巧在于 熟练使用快捷键、数据处理函数及视图工具,如Ctrl+C/V(复制粘贴)、Alt+=(自动求和)、条件格式、数据验证及数据透视表。掌握这些可大幅提升数据分析与办公效率,实现快速录入、查找、筛选和汇总。

6

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号