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" />
        )
      }
    />
  );
}
相关推荐
im_AMBER5 小时前
React 04
前端·react.js·前端框架·1024程序员节
im_AMBER11 小时前
React 06
前端·javascript·笔记·学习·react.js·前端框架
web打印社区1 天前
使用React如何静默打印页面:完整的前端打印解决方案
前端·javascript·vue.js·react.js·pdf·1024程序员节
喜欢踢足球的老罗1 天前
[特殊字符] PM2 入门实战:从 0 到线上托管 React SPA
前端·react.js·前端框架
楊无好1 天前
React中ref
前端·react.js
诚实可靠王大锤1 天前
react-native实现多列表左右滑动+滚动TabBar悬停
javascript·react native·react.js·1024程序员节
打小就很皮...1 天前
Steps + Input.TextArea + InfiniteScroll 联调优化
前端·react.js
皓月Code1 天前
第四章、路由配置
前端·javascript·react.js·1024程序员节
皓月Code2 天前
第二章、全局配置项目主题色(主题切换+跟随系统)
javascript·css·react.js·1024程序员节
楊无好2 天前
react中的受控组件与非受控组件
前端·react.js