React 页面路由ReactRouter 路由跳转 参数传递 路由配置 嵌套路由

介绍

React Router 是一个用于 React 应用程序的标准库,它允许开发者在 React 应用中实现客户端路由功能,即可以通过 URL 导航到不同的视图而不需要重新加载页面。它的核心思想是通过保持应用程序状态的同时,更新视图并保持用户的浏览体验。

安装依赖

javascript 复制代码
 npm i react-router-dom

项目结构

src/router/index.js

配置路由

javascript 复制代码
import User from "../view/user";
import Login from "../view/login";

import {createBrowserRouter} from "react-router-dom";

const router = createBrowserRouter([
    {
        path: "/",
        element: <Login></Login>, // 默认路由重定向到 /login
    },
    ,{
        path:'/login',
        element:<Login></Login>
},
    {   path:'/user',
        element:<User></User>
    }
,])

export default router

导入路由

index.js

javascript 复制代码
	import {RouterProvider} from "react-router-dom";
import router from "./router/index";

const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(
  <React.StrictMode>

    <Provider store={store}>
        <RouterProvider router={router}>
        </RouterProvider>
    </Provider>
  </React.StrictMode>
);

reportWebVitals();

路由跳转

声明式

javascript 复制代码
import { Link } from "react-router-dom";

<Link to="/user">跳转个人中心</Link>

编程式

javascript 复制代码
import { useNavigate} from "react-router-dom";
 const nav =  useNavigate()


  <button onClick={()=>{
             nav('/user')
         }}>跳转</button>

路由传参

SearchPamas传递

javascript 复制代码
 <button onClick={()=>{
             nav('/user?id=123')
         }}>跳转</button>

SearchPamas接收

javascript 复制代码
import {useSearchParams} from "react-router-dom";

const [params] =useSearchParams()
const id =params.get('id')

Pamas传递

javascript 复制代码
<button onClick={()=>{
             nav('/user/123')
         }}>跳转</button>

路由占位

javascript 复制代码
{   path:'/user/:id',
    element:<User></User>
 }

Pamas接收

javascript 复制代码
import {useParams} from "react-router-dom";

const params =useParams()
const id =params.id

嵌套路由

javascript 复制代码
import {createBrowserRouter} from "react-router-dom";

const router = createBrowserRouter([
    {
        path: "/",
        element: <Login></Login>, // 默认路由重定向到 /login
    },
    ,{
        path:'/login',
        element:<Login></Login>
},
    {   path:'/user',
        element:<User></User>,
        children:[
            {
                path:'info',
                element:<Info></Info>
            }
        ]
    }
,])

export default router
javascript 复制代码
import {Outlet} from "react-router-dom";

const User=()=>{
    return <div>
        用户页
        <Outlet></Outlet>
    </div>
}

export default  User

默认二级路由

居然到/user自动跳转到Info组件

javascript 复制代码
{   path:'/user',
        element:<User></User>,
        children:[
            {
                // path:'info',
                index:true,
                element:<Info></Info>
            }
        ]
    }

404路由配置

路由配置项最后

javascript 复制代码
{
        path:'*',
        element:<NotFound></NotFound>
    }

两种路由模式

分别是 HashRouter 和 BrowserRouter
HashRouter :aaa/#/bbb 不需要配置Nginx
BrowserRouter:aaa/bbb 需要配置Nginx

javascript 复制代码
import {createBrowserRouter,createHashRouter} from "react-router-dom";

路由懒加载

可以让我们根据需要动态地加载路由对应的模块,而不是一开始就加载所有的模块。这能显著减小初始加载时的包体积,提高页面加载速度。

javascript 复制代码
const Login =lazy(()=>import(   '../view/Login'))

 {
        path: "/",
        element: <Suspense fallback={'加载中'}><Login></Login></Suspense>,
    },
相关推荐
llz_11229 分钟前
web-第二次课后作业
前端·后端·web
vipbic6 小时前
别再把“做个H5”挂嘴边了:这个词,官方压根就没有定义过
前端
ZC跨境爬虫7 小时前
跟着 MDN 学CSS day_39:(Flexbox 弹性盒子核心机制)
前端·css·ui·html·tensorflow
小陈同学呦7 小时前
前端如何处理订单状态导航的数据竞态问题
前端·javascript
开发者每周简报8 小时前
网海三部曲·无名宗师传
javascript·人工智能
喵个咪8 小时前
GoWind Toolkit 前端代码生成|Vue3(ElementPlus/Vben)、React(AntDesign)全自动一键生成教程
前端·vue.js·react.js
摆烂大大王9 小时前
玩转 OpenClaw:用 TaskFlow + Heartbeat 打造自动化工作流
前端·人工智能·自动化
zhangxingchao9 小时前
AI 大模型核心六:量化、Workflow 与 Agent、多轮 RAG
前端·人工智能·后端
梦想的颜色9 小时前
TypeScript 完全指南(上):从零开始掌握类型系统
前端·typescript
之歆10 小时前
Day01_ES6+ 专业指南:从基础到实战的现代JavaScript开发(下)
前端·javascript·es6