React原理 即 React路由基础(下)

简介: React原理 即 React路由基础

React路由基础


目标

能够说出React路由的作用

能够掌握-react-router-dom的基本使用

能够使用编程式导航跳转路由

能够知道React路由的匹配模式

React路由介绍

现代的前端应用大多数是SPA(单页应用程序),也就是只有一个HTML页面的应用程序。因为它的用户体验更好、对服务器压力更小,所以更受欢迎。为了有效的使用单个页面来管理多页面的功能,前端路由应运而生。


前端路由功能:让用户从一个视图(页面)导航到另一个视图(页面)

前端路由是一套映射规则,在React中,是URL路径与组件的对应关系

使用React路由简单来说,就是配置路径和组件

路由的基本使用

使用步骤

安装: yarn add react-router-dom


如果没有安装yarn工具的,需要先全局安装一下yarn:npm install -g yarn

导入路由的三个核心组件: Router / Route / Link


import {BrowserRouterasRouter, Route, Link} from'react-router-dom'


使用Router 组件包裹整个应用


使用Link组件作为导航菜单(路由入口)


[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0wZKYfU9-1658295500671)(images/link入口.png)]


使用Route组件配置路由规则和要展示的组件(路由出口)

常用组件说明

**Router组件:**包裹整个应用,一个React应用只需要使用一次

两种常用的Router: HashRouter和BrowserRouter

HashRouter: 使用URL的哈希值实现 (localhost:3000/#/first)

推荐 BrowserRouter:使用H5的history API实现(localhost3000/first)

**Link组件:**用于指定导航链接(a标签)

最终Link会编译成a标签,而to属性会被编译成 a标签的href属性

**Route组件:**指定路由展示组件相关信息

path属性:路由规则,这里需要跟Link组件里面to属性的值一致

component属性:展示的组件

Route写在哪,渲染出来的组件就在哪

路由的执行过程

当我们点击Link组件的时候,修改了浏览器地址栏中的url


React路由监听地址栏url的变化


React路由内部遍历所有的Route组件,拿着Route里面path规则与pathname进行匹配


当路由规则(path)能够匹配地址栏中的pathname时,就展示该Route组件的内容


编程式导航

**场景:**点击登陆按钮,登陆成功后,通过代码跳转到后台首页,如何实现?

**编程式导航:**通过JS代码来实现页面跳转

history是React路由提供的,用于获取浏览器历史记录的相关信息

**push(path):**跳转到某个页面,参数path表示要跳转的路径

go(n):前进或后退功能,参数n表示前进或后退页面数量

默认路由

现在的路由都是通过点击导航菜单后展示的,如果进入页面的时候就主动触发路由呢

默认路由:表示进入页面时就会匹配的路由

默认路由:只需要把path设置为 '/'

匹配模式

模糊匹配模式

当Link组件的to属性值为 ‘/login’ 时候,为什么默认路由也被匹配成功?

默认情况下,React路由是模糊匹配模式

模糊匹配规则:只要pathname以path开头就会匹配成功

精准匹配

默认路由认可情况下都会展示,如果避免这种问题?

给Route组件添加exact属性,让其变为精准匹配模式

精确匹配:只有当path和pathname完全匹配时才会展示改路由

小结

React路由可以有效的管理多个视图实现 SPA

路由先需要通过安装

Router组件包裹整个应用,只需要使用一次

Link组件是入口,Route组件是出口

通过props.history实现编程式导航

默认是模糊匹配,添加exact编程精确匹配

React路由的一切都是组件,可以像思考组件一样思考路由

相关文章
|
3月前
|
前端开发 JavaScript
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
本文介绍了在React项目中实现路由懒加载的方法,使用React提供的`lazy`和`Suspense`来优化项目首次加载的速度。通过将路由组件改为懒加载的方式,可以显著减少初始包的大小,从而加快首次加载速度。文章还展示了如何使用`Suspense`组件包裹`Switch`来实现懒加载过程中的fallback效果,并提供了使用前后的加载时间对比,说明了懒加载对性能的提升作用。
266 2
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
|
1月前
|
前端开发 API UED
React 路由守卫 Guarded Routes
【10月更文挑战第26天】本文介绍了 React 中的路由守卫(Guarded Routes),使用 `react-router-dom` 实现权限验证、登录验证和数据预加载等场景。通过创建 `AuthContext` 管理认证状态,实现 `PrivateRoute` 组件进行路由保护,并在 `App.js` 中使用。文章还讨论了常见问题和易错点,提供了处理异步操作的示例,帮助开发者提升应用的安全性和用户体验。
57 1
|
1月前
|
前端开发 安全 网络安全
React——路由Route
React——路由Route
38 2
React——路由Route
|
2月前
|
资源调度 前端开发 测试技术
React Router 路由管理
【10月更文挑战第10天】本文介绍了 React Router,一个在 React 应用中管理路由的强大工具。内容涵盖基本概念、安装与使用方法、常见问题及解决方案,如路由嵌套、动态路由和路由守卫等,并提供代码示例。通过学习本文,开发者可以更高效地使用 React Router,提升应用的导航体验和安全性。
340 19
|
2月前
|
前端开发 网络架构
React 路由
10月更文挑战第11天
41 2
|
2月前
|
存储 前端开发 测试技术
React Hooks 的工作原理
【10月更文挑战第1天】
|
2月前
|
前端开发 JavaScript 网络架构
实现动态路由与状态管理的SPA——使用React Router与Redux
【10月更文挑战第1天】实现动态路由与状态管理的SPA——使用React Router与Redux
51 1
|
3月前
|
前端开发 Python
React技术栈-React路由插件之自定义组件标签
关于React技术栈中React路由插件自定义组件标签的教程。
71 4
React技术栈-React路由插件之自定义组件标签
|
3月前
|
移动开发 前端开发 应用服务中间件
React两种路由模式的实现原理
React两种路由模式的实现原理
118 3
|
3月前
|
前端开发 程序员 API
React技术栈-React路由插件之react-router的基本使用
这篇博客介绍了React路由插件react-router的基本使用,包括其概念、API、以及如何通过实战案例在React应用中实现SPA(单页Web应用)的路由管理。
92 9