Home > Web Front-end > JS Tutorial > How to Navigate Outside Components in React Router v6?

How to Navigate Outside Components in React Router v6?

Susan Sarandon
Release: 2024-11-03 18:29:30
Original
374 people have browsed it

How to Navigate Outside Components in React Router v6?

Navigating Outside Components in React Router v6

In React Router v5, creating a global history object allowed for convenient navigation outside of components. However, this behavior is not immediately apparent in v6.

Customizing Navigation with a Custom Router

One approach is to create a custom router that utilizes a custom history object and manages the navigation state. Inspired by the implementation of BrowserRouter in v6:

<code class="javascript">const CustomRouter = ({ history, ...props }) => {
  const [state, setState] = useState({
    action: history.action,
    location: history.location,
  });

  useLayoutEffect(() => history.listen(setState), [history]);

  return (
    <Router {...props} location={state.location} navigationType={state.action} navigator={history} />
  );
};</code>
Copy after login

By utilizing this custom router with a custom history object, it effectively proxies the history object and manages the navigation state.

Exchanging Routers

Within the React application, you can then swap the default Router for the custom router:

<code class="javascript">export default function App() {
  return (
    <CustomRouter history={history}>
      <div className="App">
        <Routes>
          <Route path="/" element={<Home />} />
          <Route path="/profile" element={<Profile />} />
        </Routes>
      </div>
    </CustomRouter>
  );
}</code>
Copy after login

Unstable History Router

react-router-dom@6 introduced an 'unstable' HistoryRouter that allows for injection of a custom history library instance:

<code class="javascript">import { unstable_HistoryRouter as HistoryRouter } from 'react-router-dom';
import { createBrowserHistory } from 'history';

const history = createBrowserHistory({ window });

ReactDOM.render(
  <HistoryRouter history={history}>
    {/* The rest of your app goes here */}
  </HistoryRouter>,
  root
);</code>
Copy after login

Note that this API is marked unstable and may require further refinement or dependency management considerations.

RRDv6.4 with Data Routers

In RRDv6.4 with Data Routers, an 'unstable' navigate function is directly exposed by the router object:

<code class="javascript">import { createBrowserRouter } from 'react-router-dom';

const router = createBrowserRouter(...);

...

router.navigate(targetPath, options);</code>
Copy after login

The above is the detailed content of How to Navigate Outside Components in React Router v6?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template