gpt4 book ai didi

react-router - 如何在 react-router 4 中路由组件外部?

转载 作者:行者123 更新时间:2023-12-02 17:20:12 24 4
gpt4 key购买 nike

在 React 路由器 3 中 docs包括一种在组件外部导航的方法。 React router 4 似乎已经放弃了对此的支持,导航外部组件的唯一方法是 withRouter在组件上并将历史转发到您需要的任何地方。

我个人认为这是不切实际的,并且会导致更复杂和冗长的代码。因此,我的问题是:我是否缺少另一种导航外部组件的方法?

最佳答案

只需将应用包装在扩展的 BrowserRouter 中:

import { Router, Route, Switch, Redirect, BrowserRouter } from 'react-router-dom';
import { createBrowserHistory } from 'history';
export const history = createBrowserHistory();

export default class YourBrowserRouter extends BrowserRouter {
render() {
return (
<Router history={history}>
<Switch>
<Route exact path="/login" component={Login} />
</Switch>
</Router >
)
}
}

并且 import { history } ... history.push('/login') 在 react 组件之外你需要它的地方。对我来说,如果服务器以 401 响应,我想从我的 fetch 实用程序方法中重定向到登录页面。

关于react-router - 如何在 react-router 4 中路由组件外部?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43376063/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com