码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【React Router v6】编程式路由导航(useNavigate)


    在这里插入图片描述

    欢迎来到我的博客
    📔博主是一名大学在读本科生,主要学习方向是前端。
    🍭目前已经更新了【Vue】、【React–从基础到实战】、【TypeScript】等等系列专栏
    🛠目前正在学习的是🔥 R e a c t 框架 React框架 React框架🔥,中间穿插了一些基础知识的回顾
    🌈博客主页👉codeMak1r.小新的博客

    本文被专栏【React–从基础到实战】收录

    🕹坚持创作✏️,一起学习📖,码出未来👨🏻‍💻!
    在这里插入图片描述

    编程式路由导航(useNavigate)

    在router v5中,编程式路由导航只有在路由组件中才可以使用,借助的是路由组件独有的this.props.history这个属性。

    那么在router v6中呢,只要是函数组件(FC)都可以通过useNavigate这个hook来使用编程式路由导航。

    具体使用方式是:

    import { useNavigate } from 'react-router-dom';
    function Demo() {
    	const navigate = useNavigate()
      function forward() {
        // 前进
        navigate(1)
      }
      function back() {
        // 后退
        navigate(-1)
      }
    	<button onClick={forward}>前进</button>
      <button onClick={back}>后退</button>
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    useNavigate是一个函数,通过传入的值来判断函数需要执行的操作是什么。

    declare function useNavigate(): NavigateFunction;
    
    interface NavigateFunction {
      (
        to: To,
        options?: { replace?: boolean; state?: any }
      ): void;
      (delta: number): void;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    options配置项只能接受两个参数:replace和state。

    replace默认值是false,state用于传递路由组件的state参数。

    search参数以及params参数不允许在options中配置,直接在路径中传递即可。

    具体传递方式查阅本系列专栏前面的文章:

    路由组件传参params/search/state(router v6)

    传入number类型的值,代表前进与后退。

    当然还可以通过传入路径,来定向导航到指定的路径(路由组件):

    <button onClick={() => showDetail(msgObj)}>显示详情</button>
    function showDetail(msgObj) {
        navigate('detail', {
          replace: false,
          state: {
            id: msgObj.id,
            title: msgObj.title,
            content: msgObj.content
          }
        })
      }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    这段代码的含义是:点击按钮,触发showDetail函数,函数中通过编程式路由导航,跳转到子路由detail路径下,跳转的方式是push,而不是replace。并且向子路由组件Detail传递state参数。

  • 相关阅读:
    TypeError: _wrap_socket() argument ‘sock‘ must be _socket.socket, not SSLSocket
    3d标签云实现过程(tagcloud.js)同步原生和 vue
    1.9 关于小红书账号定位,这里有一整套定位方案【玩赚小红书】
    python让女友照片飞来飞去
    Win11安装权限在哪里设置?Win11安装权限设置的方法
    PIP安装
    Linux 软件管理
    spring boot 无法读取点分隔的环境变量
    Eolink 携手云体科技 ,共同构建汽车 DevOps 新生态
    【dotnet】dotnet和mono及跨平台实现原理及案例(重要)
  • 原文地址:https://blog.csdn.net/Svik_zy/article/details/126203796
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号