0

0

中级:使用 React Router 进行路由

王林

王林

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

|

1151人浏览过

|

来源于dev.to

转载

中级:使用 react router 进行路由

路由是构建现代 web 应用程序的一个重要方面。 react router 是一个功能强大的库,使开发人员能够有效地处理 react 应用程序中的客户端路由。本指南将深入研究设置 react router 的基础知识、使用基本组件,并探索高级路由技术,例如嵌套路由、动态路由、路由参数和路由防护。

react 路由器简介

react router 允许您根据 url 管理不同组件的导航和渲染。它有助于构建具有无缝导航体验的单页应用程序 (spa)。

设置 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 组件确保只渲染第一个匹配的路由。

示例:

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 属性将活动类应用于与当前路由匹配的链接。

先进的路由技术

嵌套路由

嵌套路线允许您在其他路线中创建路线,从而实现导航的分层结构。

dmSOBC SHOP网店系统
dmSOBC SHOP网店系统

dmSOBC SHOP网店系统由北京时代胜腾信息技术有限公司(http://www.webzhan.com)历时6个月开发完成,本着简单实用的理念,商城在功能上摒弃了外在装饰的一些辅助功能,尽可能的精简各项模块开发,做到有用的才开发,网店V1.0.0版本开发完成后得到了很多用户的使用并获得了好评,公司立即对网店进行升级,其中包括修正客户提出的一些意见和建议,现对广大用户提供免费试用版本,如您在使用

下载

示例:

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

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

541

2023.09.21

Java switch的用法
Java switch的用法

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

423

2024.03.13

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

9

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

9

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

8

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

3

2026.01.30

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

20

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

17

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

19

2026.01.29

热门下载

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

精品课程

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

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