react---react router 5 基本使用

这篇具有很好参考价值的文章主要介绍了react---react router 5 基本使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

1.路由介绍

2.路由使用

3.路由组件和一般组件

4.Switch 单一匹配

5.解决二级路由样式丢失的问题

6.路由精准匹配和模糊匹配

7.Redirect路由重定向


1.路由介绍

路由是根据不同的 URL 地址展示不同的内容或页面,在 SPA 应用中,大部分页面结果不改变,只改变部分内容的使用。一个路由其实就是一个映射关系。

前端路由常见的两种模式:hash和history

hash模式:路由上会有个#号,#后面 hash 值的变化,并不会导致浏览器向服务器发出请求,浏览器不发出请求,也就不会刷新页面。使用 Javascript 来对 location.hash 进行赋值,改变 URL 的hash值,每次 hash 值的变化,会触发hashchange 这个事件。然后我们便可以监听hashchange来实现更新页面部分内容的操作。

history模式:使用history模式可以让URL看起来更加友好,更符合传统的URL访问习惯,不会出现#号,更加好看。当用户刷新页面之类的操作时,浏览器会给服务器发送请求,所以这个实现需要服务器的支持,需要把所有路由都重定向到根页面(nginx配置try_files重定向到index.html),否则会出现404。HTML5 提供了 History API 来实现 URL 的变化,其中最主要的 API 有以下两个:
history.pushState() 新增一个历史记录
history.replaceState() 直接替换当前的历史记录

2.路由使用

  • 安装【npm i react-router-dom@5】
  • 引入使用到的一些标签【import{Link,Route}from 'react-router-dom'】
  • 编写路由链接【Link,NavLink】
  • 注册路由【 <Route path="/home" component={Home}></Route>】
  • 路由包裹【ReactDOM.render(<BrowserRouter> <App/> </BrowserRouter>, document.getElementById("root"));】整个 App 组件标签采用 BrowserRouter (或使用HashRouter)标签包裹,这样整个 App 组件都在一个路由器的管理下。
{/*  编写路由链接*/}
<Link to="/home">Home</Link>
<NavLink activeClassName="nav-active" to="/home">Home</NavLink>
<MyNavLink to="/home">Home</MyNavLink> //通过封装把冗长的NavLink上的标签放到组件上去了

NavLink给a标签带上了active属性(高亮设置),通过activeClassName 来修改默认的高亮类名

基于NavLink封装MyNavLink组件

【MyNavLink组件】

import React, { Component } from 'react'
import { NavLink } from 'react-router-dom/cjs/react-router-dom'

export default class MyNavLink extends Component {
  render() {
    console.log("MyNavLink接收父组件传值props",this.props);
    return (
        <NavLink activeClassName="nav-active" {...this.props}></NavLink>
    )
  }
}

在标签体内写的内容都会成为一个 children 属性,因此我们在调用 MyNavLink 时,在标签体中写的内容,都会成为 props 中的一部分。如下MyNavLink标签内的内容Home会成为props的children属性

<MyNavLink to="/home" a={1} b={2}>Home</MyNavLink>

react---react router 5 基本使用

3.路由组件和一般组件

  • 写法不同:一般组件【<Home/>】,路由组件【 <Route path="/home" component={Home} />】
  • 存放的位置不同:路由组件放在 pages 文件夹中,一般组件放在 components文件夹中
  • 最重要的一点就是它们接收到的 props 不同,在一般组件中,如果我们不进行传递,就不会收到值。而对于路由组件而言,它会接收到 3 个固定属性 history 、location 以及 match
history:
    go: ƒ go(n)
    goBack: ƒ goBack()
    goForward: ƒ goForward()
    push: ƒ push(path, state)
    replace: ƒ replace(path, state)
location:
    pathname: "/about"
    search: ""
    state: undefined
match:
    params: {}
    path: "/about"
    url: "/about"

4.Switch 单一匹配

react---react router 5 基本使用

 当/about路径匹配上了第一个About 组件后,它还会继续向下匹配Test组件,采用 Switch 组件进行包裹后只进行单一匹配,不会再向下去匹配了,可以提高路由匹配效率。

react---react router 5 基本使用

5.解决二级路由样式丢失的问题

当index.html以相对路径方式引入css文件时,【 <link href="./css/bootstrap.css" rel="stylesheet">】(该文件放在public/css路径下)在如下二级路由的情况下存在刷新页面导致样式丢失的问题。

<MyNavLink to = "/base/about" >About</MyNavLink>

<Route path="/base/about"component={About}/>

http://localhost:3000是webpack内置的服务器,通过devServer开启的。public文件夹相当于是localhost:3000的根路径。

当刷新页面后,获取bootstrap.css文件的请求路径上带了base,并且返回状态码200,请求成功,这是因为请求的资源不存在时,会把index.html响应给该请求,所以状态码为200。

react---react router 5 基本使用

react---react router 5 基本使用

 (1)使用绝对路径/

 <link href="/css/bootstrap.css" rel="stylesheet"> 

(2)使用PUBLIC_URL%

 <link href="%PUBLIC_URL%/css/bootstrap.css" rel="stylesheet">

(3)使用HashRouter

因为HashRouter会添加#,默认不会处理#后面的路径,所以也是可以解决的

6.路由精准匹配和模糊匹配

路由的匹配有两种形式,精准匹配和模糊匹配,React 中默认开启的是模糊匹配

模糊匹配可以理解为,在匹配路由时,只要有匹配到的就好了,要求输入的路径必须包含匹配的路径,且顺序要一致

<MyNavLink to = "/home/a/b" >Home</MyNavLink>
<Route path="/home"component={Home}/>

精准匹配:两者必须相同,通过exact开启严格匹配

<Route exact={true}  path="/home" component={Home}/>
或者
<Route exact path="/home" component={Home}/>

严格匹配不要随便开启,需要再开,有些时候开启会导致无法继续匹配二级路由。

7.Redirect路由重定向

当没有匹配到/home /about路径时,重定向到/home路径文章来源地址https://www.toymoban.com/news/detail-492325.html

 <Switch>
    <Route path="/home" component={Home} />
    <Route path="/about" component={About} />
    <Redirect to="/home"/>
</Switch>

到了这里,关于react---react router 5 基本使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【React】react-router 路由详解

    🚩🚩🚩 💎个人主页: 阿选不出来 💨💨💨 💎个人简介: 一名大二在校生,学习方向前端,不定时更新自己学习道路上的一些笔记. 💨💨💨 💎目前开发的专栏: JS 🍭Vue🍭React🍭 💨💨💨 前端路由就是把不同路由对应不同的内容或页面的任务交给前端来做,根据不同的url地

    2024年02月01日
    浏览(30)
  • React-路由 react-router-dom

    前端路由的功能:让用户从一个页面跳转到另一个页面。 前端路由是一套映射规则 ,在 React 中, 是 URL 路径与组件的对应关系 。 使用 React 路由简单来说就是配置 路径与组件(配对) 。 路由的本质: 一个路径 path 对应唯一的一个组件 component 当我们访问一个 path 自动把 p

    2024年02月02日
    浏览(32)
  • React 路由react-router-dom详解

    前面我们先了解一下 路由是什么? 路由分类有哪些?内置API有哪些 ? 可能有点枯燥,不喜欢看的直接跳过 ! 单页Web应用(single page web application,SPA)。 整个应用只有一个完整的页面。 点击页面中的链接不会刷新页面,只会做页面的局部更新。 数据都需要通过ajax请求获取

    2023年04月11日
    浏览(26)
  • 探索React Router:实现动态二级路由

    我有一个路由配置的二维数组,想根据这个数组结合路由组件来动态生成路由,应该怎么样实现。在 React Router 6 中渲染二级路由的方式跟 React Router 65相比有一些变化,但核心思路仍然是利用 Route 组件和路由嵌套的方式。下面是具体的步骤: 定义路由数组 注意,这里我们使用

    2024年04月25日
    浏览(20)
  • <React-Router>超全react路由知识点(跳转、传参、子路由、重定向等)

    目录 一、路由环境配置 1.搭建一个项目名为boke(自定义),编辑文档语言为TypeScript的项目环境。 2.安装所有package.json中的依赖----安装包(注意要【cd 项目名】进入项目文件安装) 3.添加React-Router路由 4.文件、目录相关修改与搭建 二、路由的懒加载  三、路由跳转 1.标签跳转(

    2024年02月11日
    浏览(41)
  • 第三十章 React的路由基本使用

    关于 React 路由,我们在学习之前先了解一下其他知识点: SPA 应用、路由的理解、 react 中如何使用路由。 SPA应用的理解 我们知道 React 脚手架给我们构建的是一个单页应用程序( SPA ),在页面加载时,只会加载一个 HTML 文件,然后使用 JavaScript 动态地更新页面内容。这意味

    2024年02月03日
    浏览(25)
  • React-Router路由基础篇(简单易学)

    文章目录 系列文章目录 前言 一、pandas是什么? 二、使用步骤 1.引入库 2.读入数据 总结 提示:这里可以添加本文要记录的大概内容: 例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。 (

    2024年04月14日
    浏览(31)
  • React07-路由管理器react-router-dom(v6)

    react-router 是一个流行的用于 React 应用程序路由的库。它使我们能够轻松定义应用程序的路由,并将它们映射到特定的组件,这样可以很容易地创建复杂的单页面应用,并管理应用程序的不同视图。 react-router 是基于 React 构建的,因此与其他 React 库和工具集成得很好。它在许

    2024年02月02日
    浏览(32)
  • React 路由使用-详细介绍

    路由初使用 srcpageArticleindex.js srcrouterindex.js srcindex.js 跳转的两种方式 方式一 :声明式导航跳转,原理是转换为 a 标签了 方式二 :命令式导航, 编程式导航是指通过useNavigate\\\"钩子得到导航方法,然后通过调用方法以命令式的形式进行路由跳转,比如想在登录请求完毕之后

    2024年02月14日
    浏览(29)
  • React Router 中的路由导航方法:push() 和 replace() 详解

    在 React Router 中, this.props.history.push() 和 this.props.history.replace() 是用于编程式导航的两个常用方法。它们允许我们在组件中动态地更改路由,并可选地传递状态参数。本文将介绍这两个方法的用法和区别。 push() 方法将在导航时创建一个新的历史记录条目,并将用户重定向到新

    2024年03月15日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包