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" />
        )
      }
    />
  );
}
相关推荐
博客zhu虎康13 分钟前
React+Ant design
javascript·react.js·ecmascript
一只小阿乐4 小时前
react 封装弹框组件 传递数据
前端·javascript·react.js
禁止摆烂_才浅5 小时前
前端开发小技巧-【JavaScript】- 获取元素距离 document 顶部的距离
前端·javascript·react.js
打小就很皮...14 小时前
基于 Dify 实现 AI 流式对话:组件设计思路(React)
前端·react.js·dify·流式对话
一只小阿乐14 小时前
前端react 开发 图书列表分页
前端·react.js·react·ant-
IT古董14 小时前
在 React 项目中使用 Ky 与 TanStack Query 构建现代化数据请求层
前端·react.js·前端框架
小程故事多_8014 小时前
LangGraph系列:多智能体终极方案,ReAct+MCP工业级供应链系统
人工智能·react.js·langchain
Java追光着16 小时前
React Native 自建 JS Bundle OTA 更新系统:从零到一的完整实现与踩坑记录
javascript·react native·react.js
努力往上爬de蜗牛16 小时前
react native 运行问题和调试 --持续更新
javascript·react native·react.js
用户904438163246018 小时前
React 5 个 “隐形坑”:上线前没注意,debug 到凌晨 3 点
前端·javascript·react.js