react路由01——react-routerV6 中路由传递参数的几种方式

news2024/11/20 13:16:43

react路由01——react-routerV6 中路由传递参数的几种方式

  • 1. 前言
    • 1.1 关于react- router,上官网
    • 1.2 react脚手架demo
  • 2. 路由简单配置——无参数
  • 3. 路由传参方式
    • 3.1 params参数
      • 3.1.1 params参数——useParams钩子
      • 3.1.2 params参数——useMatch钩子
    • 3.2 search参数
      • 3.2.1 search参数——useSearchParams钩子
        • 3.2.1.1 官方介绍
        • 3.2.1.2 searchParams——读取
        • 3.2.1.3 setSearchParams——修改
      • 3.2.2 search参数——useLocation钩子
        • 3.2.2.1 获取参数
        • 3.2.2.1 将获取的Location参数转对象——query-string
    • 3.3 state参数
      • 3.3.1 传参方式
      • 3.3.2 接受参数方式——useLocation钩子
      • 3.3.3 效果
  • 4. 总结
    • 4.1 params参数
    • 4.2 search参数
    • 4.3 state参数

1. 前言

1.1 关于react- router,上官网

  • 官方文档
    https://reactrouter.com/en/main.
  • 官方例子
    https://github.com/remix-run/react-router/tree/dev/examples.

1.2 react脚手架demo

  • 请看上篇文章,如下:
    创建react脚手架项目——demo(react18 + react-router 6).

2. 路由简单配置——无参数

  • 写法如下:
    在这里插入图片描述
  • 核心代码,如下:
     <Link to='/cats/info/'>
         {cat.catId}--{cat.catName}
     </Link>
    
     <Routes>
          <Route path='info' element={<CatInfo/>} />
     </Routes>
    
  • 效果
    在这里插入图片描述

3. 路由传参方式

3.1 params参数

3.1.1 params参数——useParams钩子

  • 要求:路由表配置的位置添加参数占位。
  • 实现方式如下:
    在这里插入图片描述
  • 核心代码如下:
    • cats.jsx,如下:
      import React from "react";
      import CatInfo from "./Info/CatInfo";
      import {Route,Routes,Link} from 'react-router-dom'
      
      class Cats extends React.Component{
          state = {
              cats:[
                  {catId:'A1001',catName:'点点'},
                  {catId:'A1002',catName:'阿苔'},
                  {catId:'A1003',catName:'花花'}
              ]
          };
          render(){
              const {cats} = this.state;
              return(
                  <div>
                      <h2>猫咪信息</h2>
                      <ul>
                          {
                              cats.map((cat)=>{
                                  return(
                                      <li key={cat.catId}>
                                          {/* 编写路由链接 */}
                                          <Link to={`/cats/info/${cat.catId}`}>
                                              {cat.catId}--{cat.catName}
                                          </Link>
                                      </li>
                                  )
                              })
                          }
                      </ul>
                      <br /><br />
                      <Routes>
                          {/* 注册路由 */}
                           <Route path='info/:catId' element={<CatInfo/>} />
                      </Routes>
                  </div>
              )
          }
      }
      export default Cats;
      
    • catInfo.jsx,如下:
      import React from "react";
      import { useParams } from "react-router-dom";
      import './catInfo.css'
      
      //数据备用   根据传来的catId 查找要展示的数据
      let catList = [
          {catId:'A1001',catName:'点点',catAge:5,catKind:'德文'},
          {catId:'A1002',catName:'阿苔',catAge:6,catKind:'德文'},
          {catId:'A1003',catName:'花花',catAge:2,catKind:'布偶'}
      ]
      
      export default function CatInfo(){
          const {catId} = useParams();//获取路由传递来的参数
          // 根据传递过来的catId 查找对应的数据
          const cat = catList.find((obj)=>{
              return obj.catId === catId;
          })
          return(
              <div>
                  <hr />
                  <table>
                      <caption>猫咪信息</caption>
                      <thead>
                          <tr>
                              <th>编号</th><th>姓名</th><th>年龄</th><th>品种</th>
                          </tr>
                      </thead>
                      <tbody >
                          <tr>
                              <td>{cat.catId}</td>
                              <td>{cat.catName}</td>
                              <td>{cat.catAge}</td>
                              <td>{cat.catKind}</td>
                          </tr>
                      </tbody>
                  </table>
              </div>
          )
      }
      
  • 效果如下:
    在这里插入图片描述

3.1.2 params参数——useMatch钩子

  • 传参数与上一致,如下:

    <li key={cat.catId}>
        {/* 编写路由链接 */}
        <Link to={`/cats/info/${cat.catId}/${cat.catName}`}>
                {cat.catId}--{cat.catName}
        </Link>
    </li>
    
    <Routes>
        {/* 注册路由 */}
        <Route path='info/:catId/:catName' element={<CatInfo/>} />
    </Routes>
    
  • 取参数如下:

    import { useMatch } from "react-router-dom";
    const data = useMatch('/cats/info/:catId/:catName');
    console.log(data);
    
    const {params} = useMatch('/cats/info/:catId/:catName');
    console.log(params.catName);
    
  • 效果如下:
    在这里插入图片描述

3.2 search参数

3.2.1 search参数——useSearchParams钩子

3.2.1.1 官方介绍

  • useSearchParams 钩子用于读取修改当前位置 URL 中的查询字符串。
  • 与 React 自己的 useState 钩子一样,useSearchParams 返回一个包含两个值的数组:当前位置的搜索参数和一个可用于更新参数的函数
  • 与 React 的 useState 钩子一样,setSearchParams 也支持功能更新。因此,您可以提供一个接收 searchParams 并返回更新版本的函数。

3.2.1.2 searchParams——读取

  • 说明:
    • search 传参的方式比较简单,参数的形式以 问号拼接 到地址后面。
    • 注册路由时不用占位。
  • 实现方式,如下:
    在这里插入图片描述
  • 核心代码,如下:
    • cats组件
      import React from "react";
      import CatInfo from "./Info/CatInfo";
      import {Route,Routes,Link} from 'react-router-dom'
      
      class Cats extends React.Component{
          state = {
              cats:[
                  {catId:'A1001',catName:'点点'},
                  {catId:'A1002',catName:'阿苔'},
                  {catId:'A1003',catName:'花花'}
              ]
          };
          render(){
              const {cats} = this.state;
              return(
              <div>
                  <h2>猫咪信息</h2>
                  <ul>
                      {
                          cats.map((cat)=>{
                              return(
                                  <li key={cat.catId}>
                                      {/* 编写路由链接 */}
                                      <Link to={`/cats/info?catId=${cat.catId}&catName=${cat.catName}`}>
                                          {cat.catId}--{cat.catName}
                                      </Link>
                                  </li>
                              )
                          })
                      }
                  </ul>
                  <br /><br />
                  <Routes>
                      {/* 注册路由 */}
                          <Route path='info/' element={<CatInfo/>} />
                  </Routes>
              </div>
              )
          }
      }
      export default Cats;
      
    • catInfo组件
      import React from "react";
      // import { useParams } from "react-router-dom";
      import { useSearchParams } from "react-router-dom";
      import './catInfo.css'
      
      //数据备用   根据传来的catId 查找要展示的数据
      let catList = [
          {catId:'A1001',catName:'点点',catAge:5,catKind:'德文'},
          {catId:'A1002',catName:'阿苔',catAge:6,catKind:'德文'},
          {catId:'A1003',catName:'花花',catAge:2,catKind:'布偶'}
      ]
      
      export default function CatInfo(){
          // const {catId} = useParams();//获取路由传递来的参数
          let [searchParams, setSearchParams] = useSearchParams();// 获取问号传递来的参数
          // console.log(searchParams);
          const catId = searchParams.get('catId'); //取参数通过 searchParams.get('key')
          const catName = searchParams.get('catName');
          console.log(catId,'---->',catName);
      
          // 根据传递过来的catId 查找对应的数据
          const cat = catList.find((obj)=>{
              return obj.catId === catId;
          })
          return(
              <div>
                  <hr />
                  <table>
                      <caption>猫咪信息</caption>
                      <thead>
                          <tr>
                              <th>编号</th><th>姓名</th><th>年龄</th><th>品种</th>
                          </tr>
                      </thead>
                      <tbody >
                          <tr>
                              <td>{cat.catId}</td>
                              <td>{cat.catName}</td>
                              <td>{cat.catAge}</td>
                              <td>{cat.catKind}</td>
                          </tr>
                      </tbody>
                  </table>
              </div>
          )
      }
      
  • 效果如下:
    在这里插入图片描述

3.2.1.3 setSearchParams——修改

  • 看官网例子
    在这里插入图片描述
  • 举个小例子,如下:
    在这里插入图片描述

3.2.2 search参数——useLocation钩子

3.2.2.1 获取参数

  • 代码如下:

    import { useLocation } from "react-router-dom";
    
    
    console.log("======使用useLocation======");
    const data = useLocation();
    console.log(data);
    
  • 效果如下:
    在这里插入图片描述

3.2.2.1 将获取的Location参数转对象——query-string

  • 首先安装
    npm i query-string
    
  • 引入 query-string 库
    import queryString from "query-string"
    
  • 转换成对象
    const data = useLocation();
    console.log(data);
    
    const dataObj =  queryString.parse(data.search); //转对象
    console.log(dataObj);
    
    在这里插入图片描述
  • 效果如下:
    在这里插入图片描述
  • 补充——将对象转换成location参数形式:
    • 代码如下:
      console.log("======obj转location======");
      const locationStr = queryString.stringify(dataObj);
      console.log(locationStr);
      
    • 效果如下:
      在这里插入图片描述

3.3 state参数

3.3.1 传参方式

  • 如下:
    在这里插入图片描述
     <li key={cat.catId}>
         {/* 编写路由链接 */}
         {/* 传递state参数 */}
         <Link to="/cats/info" state={{catId:cat.catId,catName:cat.catName}}>
             {cat.catId}--{cat.catName}
         </Link>
     </li>
    
    <Routes>
        {/* 注册路由 */}
        <Route path='info/' element={<CatInfo/>} />
    </Routes>
    

3.3.2 接受参数方式——useLocation钩子

  • 如下:

    import { useLocation } from "react-router-dom";
    
    const data = useLocation();
    let catId = data.state.catId;
    

    在这里插入图片描述

3.3.3 效果

  • 如下:
    在这里插入图片描述

4. 总结

4.1 params参数

取参方式,如下

  • useParams钩子

    • 路由链接 代码
      <Link to={`/cats/info/${cat.catId}`}>
      	 {cat.catId}--{cat.catName}
      </Link>
      
    • 注册路由 代码
      <Routes>
      	{/* 注册路由 */}
      	<Route path='info/:catId' element={<CatInfo/>} />
      </Routes>
      
    • 取参 代码
      import { useParams } from "react-router-dom";
      
      const {catId} = useParams();//获取路由传递来的参数
      
  • useMatch钩子

    • 路由链接 代码
      <Link to={`/cats/info/${cat.catId}/${cat.catName}`}>
              {cat.catId}--{cat.catName}
      </Link>
      
    • 注册路由 代码
      <Routes>
          {/* 注册路由 */}
          <Route path='info/:catId/:catName' element={<CatInfo/>} />
      </Routes>
      
    • 取参 代码
      import { useMatch } from "react-router-dom";
      
      const {params} = useMatch('/cats/info/:catId/:catName');
      console.log(params.catName);
      

4.2 search参数

取参方式,如下

  • useSearchParams钩子
    • 路由链接 代码
      <Link to={`/cats/info?catId=${cat.catId}&catName=${cat.catName}`}>
          {cat.catId}--{cat.catName}
      </Link>
      
    • 注册路由 代码
      <Routes>
          {/* 注册路由 */}
          <Route path='info/' element={<CatInfo/>} />
      </Routes>
      
    • 取参 代码
      import { useSearchParams } from "react-router-dom";
      
      let [searchParams, setSearchParams] = useSearchParams();// 获取问号传递来的参数
      // console.log(searchParams);
      const catId = searchParams.get('catId'); //取参数通过 searchParams.get('key')
      const catName = searchParams.get('catName');
      
  • useLocation钩子
    • 路由链接 代码(同上useSearchParams)
    • 注册路由 代码(同上useSearchParams)
    • 取参 代码
      import { useLocation } from "react-router-dom";
      import queryString from "query-string"
      
      const data = useLocation();
      console.log(data);
      
      const dataObj =  queryString.parse(data.search); //转对象
      console.log(dataObj);
      

4.3 state参数

取参方式,如下

  • useLocation钩子
    • 路由链接 代码
      {/* 传递state参数 */}
      <Link to="/cats/info" state={{catId:cat.catId,catName:cat.catName}}>
          {cat.catId}--{cat.catName}
      </Link>
      
    • 注册路由 代码
      <Routes>
          {/* 注册路由 */}
          <Route path='info/' element={<CatInfo/>} />
      </Routes>
      
    • 取参 代码
      import { useLocation } from "react-router-dom";
      
      const data = useLocation();
      let catId = data.state.catId;
      

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

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

相关文章

FFmpeg深入学习

文章目录 前言一、FFmpeg 基础指令二、FFmpeg 应用之视频播放器1、音视频播放流程2、音视频同步 三、FFplay 播放器1、FFmpeg 播放器的整体框架2、ffplay 的初体验及快捷键3、ffplay 模块划分4、ffplay 原理及流程 四、FFmpeg 编解码及转码1、FFmpeg 转码全流程简介2、FFmpeg 转…

某网站小说CSS反爬实战分析

由于是刚开始编写js逆向类型的文章&#xff0c;难免会有不详细之处&#xff0c;敬请谅解 本次的目标是hongshu网的小说接口&#xff0c;我们进入官网随意找到一篇小说后&#xff0c;打开网络请求&#xff0c;分析接口 如图&#xff0c;可以看到有个bookajax.do 的接口让人值得…

Postman使用_断言测试

断言测试可以在Collection、Folder和Request的 pre-request script 和 test script中编写&#xff0c;测试脚本可以检测请求响应的各个方面&#xff0c;包括正文、状态代码、头、cookie、响应时间等&#xff0c;只有测试符合自定义的要求后才能通过。 pm对象提供了测试相关功能…

STM32 CAN使用记录:bxCAN基础通讯

文章目录 目的关键配置与代码轮询方式中断方式收发测试 示例链接总结 目的 CAN是非常常用的一种数据总线&#xff0c;被广泛用在各种车辆系统中。这篇文章将对STM32中CAN的使用做个示例。 CAN的一些基础介绍可以参考下面文章&#xff1a; 《CAN基础概念》https://blog.csdn.n…

uniapp运行到IOS真机提示 错误:请查看是否设备未加入到证书列表或者确认证书类型是否匹配

参考文章&#xff1a;请查看是否设备未加入到证书列表或者确认证书类型是否匹配 ios开发描述文件必须绑定调试设备&#xff0c;只有授权的设备才可以直接安装基座&#xff0c;所以在申请开发描述文件之前&#xff0c;先添加调试的IOS设备。 前往网站https://developer.apple.…

帧结构的串行数据接收器——Verilog实现

用Verilog 实现一个帧结构的串行数据接收器&#xff1b; 串行数据输入为&#xff1a;NRZ数据加位时钟&#xff08;BCL&#xff09;格式&#xff0c;高位在前 帧结构为&#xff1a;8位构成一个字&#xff0c;64字构成一个帧。每帧的第一个字为同步字。同步字图案存储在可由CPU读…

【自动驾驶决策规划】POMDP之Introduction

文章目录 前言Markov PropertyMarkov ChainHidden Markov ModelMarkov Decision ProcessPartially Observable Markov Decision ProcessBackground on Solving POMDPsPOMDP Value Iteration Example 推荐阅读与参考 前言 本文是我学习POMDP相关的笔记&#xff0c;由于个人能力…

阿里云CDN缓存配置及优化-oss绑定CDN缓存自动刷新功能

参考阿里云官网文档&#xff1a;https://help.aliyun.com/practice_detail/603170 1.缓存时间配置 在缓存管理中&#xff0c;可以方便地指定目录和文件后缀名在CDN节点上的缓存时间&#xff0c;缓存时长配置的长短&#xff0c;取决于源站对该文件的变更频率。我们需要分析下业务…

前后端分离毕设项目之springboot同城上门喂遛宠物系统(内含文档+源码+教程)

博主介绍&#xff1a;✌全网粉丝10W,前互联网大厂软件研发、集结硕博英豪成立工作室。专注于计算机相关专业毕业设计项目实战6年之久&#xff0c;选择我们就是选择放心、选择安心毕业✌ &#x1f345;由于篇幅限制&#xff0c;想要获取完整文章或者源码&#xff0c;或者代做&am…

项目:UDP聊天室

UDP UDP&#xff08;User Datagram Protocol&#xff09;是一种无连接、不可靠、面向数据报的传输协议。与TCP相比&#xff0c;UDP更加轻量级&#xff0c;不提供像TCP那样的可靠性和流控制机制&#xff0c;但具备较低的通信延迟和较少的开销。 UDP具有以下几个特点&#xff1…

数据中台基本概念

数据中台 数据中台&#xff08;Data Midway&#xff09;是一个用于集成、存储、管理和分析数据的中心化平台或架构。它的目标是将组织内散布在各个系统、应用程序和数据源中的数据整合到一个可统一访问和管理的中心位置&#xff0c;以支持数据驱动的决策制定和业务需求。 数据…

单片机第三季-第二课:STM32存储器、电源和时钟体系

目录 1&#xff0c;存储器 1.1&#xff0c;位带操作 2&#xff0c;启动模式 3&#xff0c;电源管理系统 4&#xff0c;复位和时钟 4.1&#xff0c;复位 4.2&#xff0c;时钟 1&#xff0c;存储器 ICode总线&#xff1a; 该总线将Cortex™-M3内核的指令总线与闪存指…

Flutter插件之阿里百川

上一篇&#xff1a;Flutter插件的制作和发布&#xff0c;我们已经了解了如何制作一个通用的双端插件&#xff0c;本篇就带领大家将阿里百川双端sdk制作成一个flutter插件供项目调用&#xff01; 目录 登录并打开控制台&#xff0c;创建应用&#xff1a;填写应用相关信息开通百川…

Vue--1.6计算属性

概念&#xff1a;基于现有的数据&#xff0c;计算出来的新属性。依赖的数据变化&#xff0c;自动重新计算。 语法&#xff1a; 1&#xff09;声明在computed配置项中&#xff0c;一个计算属性对应一个函数。 2&#xff09;使用起来和普通属性一样使用{{计算属性名}} <!do…

Java/ExecutorService中多线程服务ExecuteService的使用

什么是ExecutorService ExecutorService 是 Java 中的一个接口&#xff0c;它扩展了 Executor 接口&#xff0c;并提供了更多的方法来处理多线程任务。它是 Java 中用于执行多线程任务的框架之一&#xff0c;可以创建一个线程池&#xff0c;将多个任务提交到线程池中执行。Exe…

【深度学习】 Python 和 NumPy 系列教程(十五):Matplotlib详解:2、3d绘图类型(1):线框图(Wireframe Plot)

目录 一、前言 二、实验环境 三、Matplotlib详解 1、2d绘图类型 2、3d绘图类型 0. 设置中文字体 1. 线框图&#xff08;Wireframe Plot&#xff09; 一、前言 Python是一种高级编程语言&#xff0c;由Guido van Rossum于1991年创建。它以简洁、易读的语法而闻名&#xff0…

C++模版基础

代码地址 gitgithub.com:CHENLitterWhite/CPPWheel.git 专栏介绍 本专栏会持续更新关于STL中的一些概念&#xff0c;会先带大家补充一些基本的概念&#xff0c;再慢慢去阅读STL源码中的需要用到的一些思想&#xff0c;有了一些基础之后&#xff0c;再手写一些STL代码。 (如果你…

Flink、Spark、Hive集成Hudi

环境描述: hudi版本:0.13.1 flink版本:flink-1.15.2 spark版本:3.3.2 Hive版本:3.1.3 Hadoop版本:3.3.4 一.Flink集成Hive 1.拷贝hadoop包到Flink lib目录 hadoop-client-api-3.3.4.jar hadoop-client-runtime-3.3.4.jar 2.下载上传flink-hive的jar包 flink-co…

【蓝桥杯选拔赛真题60】Scratch旋转风车 少儿编程scratch图形化编程 蓝桥杯选拔赛真题解析

目录 scratch旋转风车 一、题目要求 编程实现 二、案例分析 1、角色分析

腾讯mini项目-【指标监控服务重构】2023-07-30

今日已办 调研 CPU & Memory Cadivisor &#xff23;adivisor -> Prometheus -> (Grafana / SigNoz Web) google/cadvisor: Analyzes resource usage and performance characteristics of running containers. (github.com) services:cadvisor:image: gcr.io/ca…