首頁 >web前端 >js教程 >如何以程式設計方式在 React Router v4、v5 和 v6 中導航?

如何以程式設計方式在 React Router v4、v5 和 v6 中導航?

Susan Sarandon
Susan Sarandon原創
2024-12-29 14:50:131014瀏覽

How to Programmatically Navigate in React Router v4, v5, and v6?

使用 React Router 以程式設計方式導覽

在 React Router 中,Link 元素支援使用超連結進行本機導覽。但是,對於連結之外的程式設計導航,您可以利用以下方法。

React Router v6.6.1 及更高版本:useNavigate Hook

使用useNavigate 鉤子,如下圖所示:

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

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

  function handleClick() {
    navigate("/home");
  }

  return (
    <button type="button" onClick={handleClick}>
      Go home
    </button>
  );
}

import { useHistory } from "react-router-dom";

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

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

  return (
    <button type="button" onClick={handleClick}>
      Go home
    </button>
  );
}

  1. React Router v5.1.0 和上圖:useHistory Hook
對於功能元件,請考慮 useHistory hook:

import { withRouter } from "react-router-dom";

const Button = withRouter(({ history }) => (
  <button
    type="button"
    onClick={() => { history.push("/new-location") }}
  >
    Click Me!
  </button>
));
    React Router v4:多種方法
  1. React Router v4:多種方法

import { Route } from "react-router-dom";

const Button = () => (
  <Route
    render={({ history }) => (
      <button
        type="button"
        onClick={() => { history.push("/new-location") }}
      >
        Click Me!
      </button>
    )}
  />
);
與路由器高階組件
  1. 將歷史物件作為組件屬性注入:

const Button = (props, context) => (
  <button
    type="button"
    onClick={() => {
      context.history === history.push === history.push;
      context.history.push('/new-location')
    }}
  >
    Click Me!
  </button>
);

Button.contextTypes = {
  history: PropTypes.shape({
    push: PropTypes.func.isRequired
  })
};
組合和路線

組合和路線 渲染一條始終與當前位置匹配的無路徑路線,通過history提供history方法prop:Context透過React Context API存取歷史記錄:為了簡單起見,我們建議使用 withRouter 高階元件或透過組合渲染無路徑路由。

以上是如何以程式設計方式在 React Router v4、v5 和 v6 中導航?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn