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>,
    },
相关推荐
子兮曰14 小时前
async/await高级模式:async迭代器、错误边界与并发控制
前端·javascript·github
恋猫de小郭15 小时前
2026 Flutter VS React Native ,同时在 AI 时代 VS Native 开发,你没见过的版本
android·前端·flutter
GIS之路17 小时前
ArcGIS Pro 中的 Notebooks 入门
前端
IT_陈寒18 小时前
React状态管理终极对决:Redux vs Context API谁更胜一筹?
前端·人工智能·后端
gxp12319 小时前
初学React:请求数据参数未更新 && 数据异步状态更新问题
react.js
Kagol19 小时前
TinyVue 支持 Skills 啦!现在你可以让 AI 使用 TinyVue 组件搭建项目
前端·agent·ai编程
柳杉19 小时前
从零打造 AI 全球趋势监测大屏
前端·javascript·aigc
simple_lau19 小时前
Cursor配置MasterGo MCP:一键读取设计稿生成高还原度前端代码
前端·javascript·vue.js
睡不着先生19 小时前
如何设计一个真正可扩展的表单生成器?
前端·javascript·vue.js
天蓝色的鱼鱼19 小时前
模块化与组件化:90%的前端开发者都没搞懂的本质区别
前端·架构·代码规范