当前位置:首页 > React

react如何写跳转

2026-01-24 08:02:37React

使用 React Router 进行页面跳转

React 应用中通常使用 react-router-dom 库实现页面跳转。以下是几种常见的跳转方式:

安装依赖包

npm install react-router-dom

在根组件中配置路由

import { BrowserRouter as Router, Route, Routes } from 'react-router-dom';
import Home from './Home';
import About from './About';

function App() {
  return (
    <Router>
      <Routes>
        <Route path="/" element={<Home />} />
        <Route path="/about" element={<About />} />
      </Routes>
    </Router>
  );
}

编程式导航跳转

在函数组件中使用 useNavigate hook

import { useNavigate } from 'react-router-dom';

function Home() {
  const navigate = useNavigate();

  const handleClick = () => {
    // 跳转到 about 页面
    navigate('/about');

    // 带参数跳转
    navigate('/about', { state: { id: 123 } });

    // 替换当前历史记录
    navigate('/about', { replace: true });
  };

  return <button onClick={handleClick}>Go to About</button>;
}

声明式导航跳转

使用 Link 组件

import { Link } from 'react-router-dom';

function Nav() {
  return (
    <nav>
      <Link to="/">Home</Link>
      <Link to="/about">About</Link>
      <Link to="/user/123">User Profile</Link>
    </nav>
  );
}

路由参数传递和获取

定义带参数的路由

<Route path="/user/:id" element={<User />} />

在目标组件中获取参数

import { useParams } from 'react-router-dom';

function User() {
  const { id } = useParams();
  return <div>User ID: {id}</div>;
}

获取路由状态

使用 useLocation 获取路由状态

import { useLocation } from 'react-router-dom';

function About() {
  const location = useLocation();
  const state = location.state; // 获取 navigate 传递的 state

  return <div>Received state: {state?.id}</div>;
}

重定向

使用 Navigate 组件进行重定向

react如何写跳转

import { Navigate } from 'react-router-dom';

function ProtectedRoute({ isLoggedIn, children }) {
  if (!isLoggedIn) {
    return <Navigate to="/login" replace />;
  }
  return children;
}

这些方法覆盖了 React 应用中常见的路由跳转场景,可以根据具体需求选择合适的方式实现页面导航功能。

标签: 跳转如何写
分享给朋友:

相关文章

vue实现导航跳转

vue实现导航跳转

vue-router 基本跳转方法 在 Vue 项目中实现导航跳转主要通过 vue-router 完成。安装路由依赖: npm install vue-router 在 router/index.j…

vue实现链接跳转

vue实现链接跳转

路由配置 在Vue项目中实现链接跳转通常使用Vue Router。需先在项目中安装并配置路由。通过vue-router库定义路由路径与组件的映射关系。 安装Vue Router: npm inst…

js怎么实现网页跳转页面跳转页面跳转

js怎么实现网页跳转页面跳转页面跳转

JavaScript 实现网页跳转的方法 使用 window.location.href 跳转 通过修改 window.location.href 属性实现页面跳转,这是最常用的方式。例如: w…

vue如何实现跳转

vue如何实现跳转

Vue 实现页面跳转的方法 在 Vue 中实现页面跳转可以通过以下几种方式,具体取决于项目结构和需求。 使用 router-link 组件 router-link 是 Vue Router 提供的组…

vue页面实现跳转

vue页面实现跳转

Vue 页面跳转的实现方法 在 Vue 中实现页面跳转可以通过以下几种方式,具体选择取决于项目需求和场景。 使用 router-link 组件 router-link 是 Vue Router 提供…

vue实现多次跳转

vue实现多次跳转

Vue 实现多次跳转的方法 在 Vue 中实现多次跳转可以通过多种方式完成,以下是几种常见的方法: 使用 router.push 或 router.replace 通过 Vue Router 提供…