第五章React路由

news2025/1/10 16:25:32

文章目录

  • 一、React的基本使用
    • 1-1、react-router-dom
      • 1-1-1、react-router-dom基本使用
    • 1-2、一般组件与路由组件
    • 1-3、NavLink
    • 1-4、封装自己的组件--MyNavLink
    • 1-5、Switch的使用
    • 1-6、多级地址样式失效问题
    • 1-7、模糊匹配
    • 1-8、严格匹配
    • 1-9、Redirect重定向
    • 1-10、嵌套路由
    • 1-11、向路由组件传递参数的三种方法
    • 1-12、路由跳转的方式
      • 1-12-1、replace
      • 1-12-2、push
    • 1-13、编程式路由导航
      • 1-13-0、跳转按钮
      • 1-13-1、push
      • 1-13-2、replace
    • 1-14、withRouter

一、React的基本使用

react的路由分为web端、native端、any所有端都能使用的路由,目前学习web端的

1-1、react-router-dom

1-1-1、react-router-dom基本使用


 1. 明确好界面中的导航区、展示区
	import {Link,Route} from 'react-router-dom'
 2. 导航区的a标签改为Link标签
	<div className="list-group">
                {/* <a className="list-group-item active" href="./about.html">About</a>
                <a className="list-group-item" href="./home.html">Home</a> */}
                  <Link className="list-group-item active" to="/about">About</Link>
                  <Link className="list-group-item" to="/home">Home</Link>         
              </div>
 3. 展示区写Route标签进行路径的匹配
	<div className="panel-body">
    	{/* 注册路由 */}
      <Route path="/about" component={About} />
      <Route path="/home" component={Home} />
    </div>
 4. App组件的最外侧包裹一个<BrowserRouter></BrowserRouter> 或者<HashRouter></HashRouter>
	// 引入路由
	import { BrowserRouter } from 'react-router-dom';
	root.render(
	  // 严格模式
	  <BrowserRouter>
	    <React.StrictMode>
	      <App />
	    </React.StrictMode>
	  </BrowserRouter>
	);

1-2、一般组件与路由组件


 1. 写法不同
	一般组件:<Demo/>
	路由组件:<Route path="/demo> component={Demo}>
 2. 存放位置不同
	一般组件:component
	路由组件:pages
 3. 接收到的props不同
	一般组件:写组件标签时传递了什么,就能接收到什么
	路由组件:接收到三个固定的属性

请添加图片描述

1-3、NavLink


 1. NavLink可以实现路由链接的高亮,通过activeClassName指定样式名
 2. 标签体聂荣时一个特殊的标签属性
 3. 通过this.props.children可以获取标签体内容

1-4、封装自己的组件–MyNavLink

MyNavLink.jsx

import React, { Component } from 'react'
import { NavLink } from 'react-router-dom'
export default class MyNavLink extends Component {
  render() {
    return (
      <NavLink className="list-group-item" {...this.props}></NavLink>
    )
  }
}

使用

import MyNavLink from './components/MyNavLink'
<NavLink className="list-group-item" to="/home">Home</NavLink>    
<MyNavLink to="/about" children="About" />     

1-5、Switch的使用

 1. 通常情况下,path和component是一一对应关系
 2. Switch可以提高路由匹配效率(单一匹配)

1-6、多级地址样式失效问题


 1. public/index.html中引入样式不写 .// (常用)
 2. public/index.html中引入样式不写 ./%PUBLIC_URL% 
 3. 使用HashRouter

1-7、模糊匹配

这样也行

<MyNavLink to="/about/q" children="About" />   
          
{/* 注册路由 */}
<Route path="/about" component={About} />
             

1-8、严格匹配

开启exact就不行了

<MyNavLink to="/about/q" children="About" />   
<Route exact path="/about" component={About} />

1-9、Redirect重定向

当路由都匹配不上的时候重定向到/about

 {/* 注册路由 */}
<Route exact path="/about" component={About} />
<Route path="/home" component={Home} />
<Redirect to="/about" />

1-10、嵌套路由


 1. 注册子路由时要写上父路由的path值
 2. 路由匹配时按照注册路由的顺序进行的

 <div className="panel-body">
            <div>
              <h2>Home组件内容</h2>
              <div>
                <ul className="nav nav-tabs">
                  <li>
                  <MyNavLink to="/home/news" children="news" />
                  </li>
                  <li>
                  <MyNavLink to="/home/message" children="message" />
                  </li>
                </ul>
              </div>

              {/* 注册路由 */}
              <Switch>
                  <Route path="/home/news" component={News} />
                  <Route path="/home/message" component={Message} />
                  <Redirect to="/home"  />
              </Switch>
            </div>
          </div>

1-11、向路由组件传递参数的三种方法

1.params参数

	路由链接(携带参数):<Link to={`/home/message/detail/${msgObj.id}`}>{msgObj.title}</Link>
	注册路由(声明接收):<Route path="/home/message/detail/:id" component={Detail} />
          
	接收参数:const {id} = this.props.match.params

2.search参数

	路由链接(携带参数):<Link to={`/home/message/detail?id=${msgObj.id}`}>{msgObj.title}</Link>
	注册路由不需要声明<Route path="/home/message/detail" component={Detail} />
	接收参数:const queryStr = this.props.location.search
	格式化参数:导入import qs from 'qs'
	使用qs格式化const {id} = qs.parse(queryStr.slice(1)) 

3.state参数

	路由链接(携带参数):<Link to={{pathname:'/home/message/detail',state:{id:msgObj.id}}}>{msgObj.title}</Link>
	接收参数:const {id} = this.props.location.state

1-12、路由跳转的方式

1-12-1、replace

<Link replace={true} to={{pathname:'/home/message/detail',state:{id:msgObj.id}}}>{msgObj.title}</Link>
不会留下痕迹

1-12-2、push

默认跳转push会留下浏览痕迹

1-13、编程式路由导航

1-13-0、跳转按钮

 <button onClick={()=>this.pushShow(msgObj.id)}>push</button>
 <button onClick={()=>this.replaceShow(msgObj.id)}>show</button>

1-13-1、push

pushShow = (id)=>{
    this.props.history.push(`/home/message/detail?id=${id}`)
  }

1-13-2、replace

replaceShow = (id)=>{
    this.props.history.replace(`/home/message/detail?id=${id}`)
  }

1-14、withRouter

一般组件中没有this.props.history属性,路由组件中才会有

可以将一个一般组件转化为路由组件

用法:

import { withRouter } from 'react-router-dom/cjs/react-router-dom.min';
 class Header extends Component {
 ...
 }
 export default withRouter(Header)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1035781.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring学习笔记3 Spring对IOC的实现

Spring学习笔记2 Spring的入门程序_biubiubiu0706的博客-CSDN博客 控制反转是一种思想 控制反转是为了降低程序耦合度,提高程序扩展力,达到OCP(开闭原则)原则,达到DIP(依赖倒置原则)原则 控制反转,反转的是什么? 1.将对象的创建权力交出去,交给第三方容器负责 2.对象与对象…

1990-2021年全国31个省人口相关统计面板数据

1990-2021年全国31个省人口相关统计面板数据 1、时间&#xff1a;1990-2021年 2、来源&#xff1a;各省统计年鉴 3、指标&#xff1a;省份代码、年份、省份名称、省份名称、常住人口数、年末常住人口 0-14岁人口数、15-64岁人口数、65岁及以上人口数、6岁及以上人口&#x…

【精品资源】Java毕业设计攻略:从选题到答辩,一站式指南

导读&#xff1a; Java毕业设计是计算机科学与技术专业学生展示其编程能力、问题解决能力和创新思维的重要环节。这篇博客将为您提供一站式的Java毕业设计攻略&#xff0c;帮助您从选题到答辩&#xff0c;顺利完成毕业设计。 一、选题阶段 寻找灵感&#xff1a; 探讨热门技术如…

【Linux】Linux环境基础开发工具使用

Linux安装软件: 源代码安装rpm安装-- Linux安装包yum安装–解决安装源&#xff0c;安装版本&#xff0c;安装依赖 目录 一、Linux 软件包管理器 yum1.查看安装包2.安装软件3.删除软件一些有趣的软件的安装&#x1f47b;1.sl 二、vim编辑器1.使用vim1.模式转换2.命令模式2.底行模…

软件设计模式系列之十三——享元模式

1 模式的定义 享元模式&#xff08;Flyweight Pattern&#xff09;是一种结构型设计模式&#xff0c;它旨在减少内存占用或计算开销&#xff0c;通过共享大量细粒度对象来提高系统的性能。这种模式适用于存在大量相似对象实例&#xff0c;但它们的状态可以外部化&#xff08;e…

人工神经网络ANN:数学总结

一、内容 径向基函数&#xff08;Radial basis function&#xff0c;RBF&#xff09;&#xff1a;一个取值仅依赖于到原点距离的实值函数&#xff0c;即。此外&#xff0c;也可以按到某一中心点c的距离来定义&#xff0c;即。 可以用于许多向函基数的和来逼近某一给定的函数&a…

SpringBoot使用@Async异步注解

首先&#xff0c;想一想为什么使用异步线程? 举个例子: 当我们请求这个接口的时候,在接口调用了method这个方法 然而被调用的方法执行了一个线程睡眠三秒 因为method方法睡眠了三秒钟,所以这个接口响应的时间肯定是大于三秒。因为接口是从上往下执行的,首先会在控制台输出一…

微信小程序python+nodejs+php+springboot+vue 讲座预约系统

讲座预约管理系统的用户是系统最根本使用者&#xff0c;按需要分析系统包括用户&#xff1a;学生、管理员。 管理员通过后台的登录页面&#xff0c;选择管理员权限后进行登录&#xff0c;管理员的权限包括学生信息管理和文章公告管理。讲座公告管理&#xff0c;添加讲座公告信息…

Swift SwiftUI 隐藏键盘

如果仅支持 iOS 15 及更高版本&#xff0c;则可以通过聚焦和取消聚焦来激活和关闭文本字段的键盘。 在最简单的形式中&#xff0c;这是使用 FocusState 属性包装器和 focusable() 修饰符完成的-第一个存储一个布尔值&#xff0c;用于跟踪第二个当前是否被聚焦。 Code struct C…

洛谷P8815:逻辑表达式 ← CSP-J 2022 复赛第3题

【题目来源】https://www.luogu.com.cn/problem/P8815https://www.acwing.com/problem/content/4733/【题目描述】 逻辑表达式是计算机科学中的重要概念和工具&#xff0c;包含逻辑值、逻辑运算、逻辑运算优先级等内容。 在一个逻辑表达式中&#xff0c;元素的值只有两种可能&a…

JDBC MySQL任意文件读取分析

JDBC MySQL任意文件读取分析 文章首发于知识星球-赛博回忆录。给主管打个广告&#xff0c;嘿嘿。 在渗透测试中&#xff0c;有些发起mysql测试流程(或者说mysql探针)的地方&#xff0c;可能会存在漏洞。在连接测试的时候通过添加allowLoadLocalInfileInPath,allowLoadLocalInf…

分类预测 | MATLAB实现WOA-CNN-GRU-Attention数据分类预测

分类预测 | MATLAB实现WOA-CNN-GRU-Attention数据分类预测 目录 分类预测 | MATLAB实现WOA-CNN-GRU-Attention数据分类预测分类效果基本描述模型描述程序设计参考资料 分类效果 基本描述 1.MATLAB实现WOA-CNN-GRU-Attention数据分类预测&#xff0c;运行环境Matlab2021b及以上&…

git学习使用

git使用 1、cmd #查看版本 git version2、初识 Git GUI: Git提供的图形界面工具 Git Bash: Git提供的命令行工具 1.打开Git Bash2.设置自己的用户名和邮箱地址git config --global user.name "xxx"git config --global user.email "123456789163.com"查…

zemaxMIF曲线图

调制传递函数&#xff08; Modulation Transfer Function&#xff0c;MTF &#xff09;是用来形容光学系统成像质量的重要指标。 通过对光学系统像空间进行傅里叶变换&#xff0c;可以得到一张分析图表&#xff0c;来描述像面上对比度和空间频率之间的对应关系。 对比度&…

DALL·E 3:大语言模型和文本生图模型的强强联合

1. 概要 就在不久之前&#xff0c;openAI官网发布了DALLE3相关内容&#xff0c;虽然现在还没有开放直接体验DALLE3的途径&#xff0c;但是我们可以先来一览DALLE3的牛逼之处。 相比之前的DALL.E2&#xff0c;DALL.E3对细节方面把握的更好。此外之前的文生图模型对prompt要求比…

Leetcode 2325.解密消息

给你字符串 key 和 message &#xff0c;分别表示一个加密密钥和一段加密消息。解密 message 的步骤如下&#xff1a; 使用 key 中 26 个英文小写字母第一次出现的顺序作为替换表中的字母 顺序 。将替换表与普通英文字母表对齐&#xff0c;形成对照表。按照对照表 替换 messag…

golang学习笔记(一):基础入门

基础入门 菜鸟教程Go语言环境安装 GoLand开发工具下载 Gin web开发框架 Go 语言流行 ORM 框架 GORM 使用介绍 如何使用Go语言连接分布式MySQL数据库 Go语言依赖搜索网站&#xff0c;类似Maven 添加依赖&#xff1a; 基础知识 1.关键字 go 开启协程执行调用语句/方法。 def…

Spring面试题9:Spring的BeanFactory和FactoryBean的区别和联系

该文章专注于面试,面试只要回答关键点即可,不需要对框架有非常深入的回答,如果你想应付面试,是足够了,抓住关键点 面试官:说一说Spring的BeanFactory和FactoryBean的区别和联系 区别:BeanFactory是一个工厂接口,主要负责管理和创建Bean实例。它是Spring提供的最底层的…

Centos7虚拟机硬盘扩容 + 修改Docker默认存储位置

文章目录 前言一、Centos7虚拟机硬盘扩容1.1 具体步骤二、修改Docker默认存储位置2.1 挂载目录2.2 修改路径 前言 Vmware 虚拟机开机时提示&#xff1a;虚拟机根目录系统内存不足&#xff0c;可能原因是 /var/lib/docker 目录占用的磁盘空间不够了。本文记录虚拟机磁盘扩容过程…

Doris数据库FE——SQL handleQuery

SQL解析在下文中指的是将一条sql语句经过一系列的解析最后生成一个完整的物理执行计划的过程。这个过程包括以下四个步骤&#xff1a;词法分析、语法分析、生成逻辑计划、生成物理计划。Doris SQL解析具体包括了六个步骤&#xff1a;词法分析&#xff0c;语法分析、语义分析&am…