news 2026/4/15 16:44:07

React Router v7数据模式使用指南

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
React Router v7数据模式使用指南

React Router官方文档:https://reactrouter.com.cn/

react-router中路由模式分为:框架模式、 数据模式、声明式模式

以下仅为 * 数据模式 * 的使用笔记

  1. 安装 当前版本v7
npm install react-router
  1. 使用createBrowserRouter创建路由配置,支持普通路由和嵌套路由。router/index.js
import{createBrowserRouter}from"react-router";importIndexfrom"@/pages/Index";importUserfrom"@/page/User";importLoginfrom"@/page/Login";constrouter=createBrowserRouter([// 普通路由{path:"/",Component:Index,},// 嵌套路由{path:"/user",Component:User,children:[{// path: "login",index:true,// 默认路由Component:Login,},{path:"register",Component:Register,},]}]);exportdefaultrouter;
  1. 使用RouterProvider绑定路由 main.js
import{RouterProvider}from"react-router/dom";importrouterfrom"./router/index.js";createRoot(document.getElementById("root")).render(<StrictMode><Provider store={store}>{/* <App /> */}{/* 绑定路由 */}<RouterProvider router={router}/></Provider></StrictMode>);

组件内通过Outlet展示子路由,Link/NavLink实现导航

import{Outlet,Link}from"react-router";exportdefaultfunctionUser(){return(<div><h1>用户</h1><Link to="/user">登录</Link><Link to="/user/register">注册</Link>{/* 二级路由出口 */}<Outlet/></div>);}
  1. 路由导航
  • 4.1 Link
import{Link}from"react-router";<Link to="/">首页</Link><Link to="/about">关于</Link>
  • 4.2 NavLink 需要渲染活跃和待处理状态的导航链接
import{NavLink}from"react-router";<NavLink to="/messages"className={({isActive,isPending,isTransitioning})=>[isPending?"pending":"",isActive?"active":"",isTransitioning?"transitioning":"",].join(" ")}>Messages</NavLink>
  • 4.3 Form
<Form action="/search"><input type="text"name="q"/></Form>
  • 4.4 重定向redirect
import{redirect}from"react-router";exportasyncfunctionloader({request}){letuser=awaitgetUser(request);if(!user){returnredirect("/login");}return{userName:user.name};}
  • 4.5 编程式 useNavigate
import{useNavigate}from"react-router";exportfunctionuseLogoutAfterInactivity(){letnavigate=useNavigate();useFakeInactivityHook(()=>{// navigate("/logout");// 使用navigate函数并设置replace为true来替换当前历史记录navigate("/logout",{replace:true});});}
  • 4.6 路由导航传参 useSearchParams 、useParams
// 4.6.1 searchParams传参navigate("/user?id=123");// 取const[params]=useSearchParams();letid=params.get("id");// 4.6.2 params传参navigate("/user/123");// 取const[params]=useParams();letid=params.id;

Hooks解析

useLocation: 返回当前的 Location,包含有关 URL 路径的信息,以及可能的一些任意状态和键。

// 属性{"pathname":"/index",// URL 路径名,以 / 开头。"search":"",// URL 查询字符串,以 ? 开头。"hash":"",// URL 片段标识符,以 # 开头。"state":null,// 与此 location 关联的任意数据值。"key":"f5ecz0os"// 与此 location 关联的唯一字符串。 可用于在其他存储 API(如 localStorage)中安全地存储和检索数据。注意:此值在初始 location 上始终为 "default"。}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 4:13:03

手把手教你部署VSCode中的量子模拟内核:7个专业级配置步骤

第一章&#xff1a;VSCode Jupyter 量子模拟内核概述 VSCode 与 Jupyter Notebook 的深度集成&#xff0c;为量子计算开发者提供了高效、直观的编程环境。通过 Python 内核运行量子模拟代码&#xff0c;用户可以在交互式单元格中设计量子电路、执行测量并可视化结果。该环境广泛…

作者头像 李华
网站建设 2026/4/15 6:41:56

【量子安全合规新标准】:基于MCP SC-400的6步审计落地法

第一章&#xff1a;MCP SC-400量子安全审计的核心理念 在后量子计算时代&#xff0c;传统加密体系面临前所未有的破解风险。MCP SC-400量子安全审计框架应运而生&#xff0c;旨在构建一套面向未来、具备抗量子攻击能力的安全验证机制。该框架不仅评估现有系统的加密强度&#x…

作者头像 李华
网站建设 2026/3/15 19:26:39

3分钟搞定Open WebUI数据可视化:从零到一的终极指南

3分钟搞定Open WebUI数据可视化&#xff1a;从零到一的终极指南 【免费下载链接】open-webui Open WebUI 是一个可扩展、功能丰富且用户友好的自托管 WebUI&#xff0c;设计用于完全离线操作&#xff0c;支持各种大型语言模型&#xff08;LLM&#xff09;运行器&#xff0c;包括…

作者头像 李华
网站建设 2026/4/11 14:35:15

从头说下DOM XSS

Demo此问题1. 写个html 叫test.html吧<!doctype html> <html lang"zh-CN"> <head><meta charset"utf-8"><title>DOM XSS test&#xff1a;test.html</title> </head> <body><h1>DOM XSS test&#…

作者头像 李华
网站建设 2026/4/7 1:24:45

Docker Scout漏洞管理新突破(忽略规则配置全解析)

第一章&#xff1a;Docker Scout漏洞管理新突破Docker Scout 正在重塑容器安全的边界&#xff0c;通过深度集成镜像分析与实时漏洞检测&#xff0c;为开发团队提供从构建到部署全生命周期的安全洞察。其最新功能不仅支持自动扫描公共和私有镜像仓库&#xff0c;还能基于 CVE 数…

作者头像 李华
网站建设 2026/4/10 20:19:19

从开发到生产:边缘Agent Docker部署的7个关键检查项

第一章&#xff1a;从开发到生产的边缘Agent部署概览在现代分布式系统架构中&#xff0c;边缘Agent作为连接中心平台与终端设备的关键组件&#xff0c;承担着数据采集、本地决策和远程协同的职责。其部署流程跨越开发、测试、灰度发布到最终生产环境落地&#xff0c;涉及多环境…

作者头像 李华