React Router 中常用的方法总结

在 React 中使用 React Router (V5版)可以实现类似于 Vue Router 的路由跳转、获取参数和编程式导航、获取路由对象等功能。以下是一些常用的方法:

  1. 编程式导航 :您可以使用 useHistory 钩子进行编程式导航。以下是一个示例:
js 复制代码
import { useHistory } from "react-router-dom";

function HomeButton() {
  let history = useHistory();

  function handleClick() {
    history.push("/home");
  }

  return (
    <button type="button" onClick={handleClick}>
      回到首页
    </button>
  );
}
  1. 重定向 :您可以使用 Redirect 组件将用户重定向到不同的页面。以下是一个示例:
js 复制代码
import { Redirect } from "react-router-dom";

function LoginPage() {
  // ... 登录逻辑

  return (
    <div>
      {isLoggedIn ? <Redirect to="/dashboard" /> : <LoginForm />}
    </div>
  );
}
  1. 前进或后退 :您可以使用 useHistory 钩子中的 goBackgoForward 函数实现前进和后退。以下是一个示例:
js 复制代码
import { useHistory } from "react-router-dom";

function BackButton() {
  let history = useHistory();

  function handleClick() {
    history.goBack();
  }

  return (
    <button type="button" onClick={handleClick}>
      后退
    </button>
  );
}

function ForwardButton() {
  let history = useHistory();

  function handleClick() {
    history.goForward();
  }

  return (
    <button type="button" onClick={handleClick}>
      前进
    </button>
  );
}
  1. 获取 URL 中的参数 :您可以使用 useParams 钩子获取 URL 中的参数。以下是一个示例:
js 复制代码
import { useParams } from "react-router-dom";

function UserDetails() {
  let { userId } = useParams();

  return (
    <div>
      <h1>User ID: {userId}</h1>
    </div>
  );
}
  1. 获取路由信息对象 :您可以使用 useRouteMatch 钩子获取有关路由的信息。以下是一个示例:
js 复制代码
import { useRouteMatch } from "react-router-dom";

function About() {
  let match = useRouteMatch();

  return (
    <div>
      <h1>About</h1>
      <p>You are now on the "About" page.</p>
      <p>The URL matched is {match.path}.</p>
    </div>
  );
}
  1. 嵌套路由 :您可以使用 Route 组件的 path 属性和 children 属性创建嵌套路由。以下是一个示例:
js 复制代码
import { Route, Switch } from "react-router-dom";

function App() {
  return (
    <Switch>
      <Route path="/admin" component={Admin}>
        <Route path="/admin/dashboard" component={Dashboard} />
        <Route path="/admin/settings" component={Settings} />
      </Route>
    </Switch>
  );
}
  1. 守卫路由 :您可以使用 Route 组件的 render 属性或 useEffect 钩子来实现路由守卫。以下是一个示例:
js 复制代码
import { Route, Redirect } from "react-router-dom";

function PrivateRoute({ component: Component, ...rest }) {
  const isAuthenticated = // ... 检查用户是否已登录

  return (
    <Route
      {...rest}
      render={props =>
        isAuthenticated ? (
          <Component {...props} />
        ) : (
          <Redirect to="/login" />
        )
      }
    />
  );
}
相关推荐
一个处女座的程序猿O(∩_∩)O5 小时前
React 完全入门指南:从基础概念到组件协作
前端·react.js·前端框架
英俊潇洒美少年12 小时前
前端组件化开发最佳实践 + 高频面试题(Vue & React)
前端·vue.js·react.js
Ruihong15 小时前
你的 Vue 3 defineProps(),VuReact 会编译成什么样的 React?
vue.js·react.js·面试
乔江seven16 小时前
LlamaIndex 实现ReAct Agent
前端·python·react.js
Ruihong18 小时前
你的 Vue 3 生命周期,VuReact 会编译成什么样的 React?
vue.js·react.js·面试
光影少年19 小时前
开发RN项目时,如何调试iOS真机、Android真机?常见调试问题排查?
android·前端·react native·react.js·ios
Bigger21 小时前
第六章:我是如何剖析 Claude Code 的终端界面渲染原理的
前端·react.js·claude
榴莲omega21 小时前
第14天:React 工程化与设计模式
前端·react.js·设计模式
前端那点事2 天前
React 18+ 所有Hooks全解析(含实战示例,新手零踩坑)
react.js
snow_yan2 天前
AI 对话流式输出: 实现“逐字丝滑、不闪烁、不卡顿”的打字机效果
前端·react.js·openai