gpt4 book ai didi

javascript - React Router - 刷新后保持在同一页面

转载 作者:塔克拉玛干 更新时间:2023-11-02 22:59:20 25 4
gpt4 key购买 nike

我正在学习 React。我的页面有 4 个子页面,我使用 React Router 浏览这些页面。除了重新加载页面外,一切正常。当我从“主页”页面转到“关于”页面或其他页面时,没问题,但是当我刷新页面时,它会再次呈现“关于”页面一秒钟,然后将页面更改为主页(主页是默认/第一页)。我希望它停留在当前呈现的页面上,而不是在每次刷新后返回主页。index.js 文件中有我的代码,我在其中呈现整个应用程序并使用路由器:

<Provider store={store}>
<Router path="/" history={browserHistory}>
<Route path="/home" component={App}>
<Route path="/" component={Home}/>
<Route path="/allhotels" component={AllHotels}/>
<Route path="/addhotel" component={AddHotel} />
<Route path="/about" component={About} />
</Route>
<Route path="/signin" component={SignIn} />
<Route path="/signup" component={SignUp} />
</Router>
</Provider>, document.getElementById('root')

在“应用程序”中,我有导航,我在那里呈现来自 Home、AllHotels 等的其余内容。

有来自App.jsx的代码

class App extends Component {

render() {
return (
<div className="app-comp">
<Navigation />
<div> {this.props.children}</div>
</div>
)
}
}

我还附上了显示我的问题的 gif。

https://gifyu.com/image/boMp

在后端,如果它很重要,我会使用 Firebase。

提前致谢。

最佳答案

我找到了问题的原因。我在我的项目中也使用了 Firebase,它导致了问题。谢谢大家的帮助。

编辑 ============================================== ========================

Mabye 我会写下我是如何解决我的问题的,以及它的原因是什么。所以我在 auth 方法中检查用户是否登录。如果用户获得授权,我会将 / 推送到 browserHistory。这是错误的,因为每个刷新方法都在执行,然后也调用了重定向。解决方案只是检查在执行身份验证方法期间我是否在登录页面上。如果它是登录页面,那么我将 / 推送到 browserHistory,但如果不是,则不要推送任何内容。

    firebaseApp.auth().onAuthStateChanged(user => {
if (user) {
let currentPathname = browserHistory.getCurrentLocation().pathname;
if( currentPathname === "/" || currentPathname === "/signin"){
browserHistory.push('/');
}
const { email } = user;
store.dispatch(logUser(email));
}
else {
browserHistory.replace('/signin');
}
})

我知道这不是很好的解决方案,但它确实有效,而且它只是为学习 React 而创建的家庭项目。 (顺便说一句,这个项目使用的是旧的 React Router 3.0,所以现在使用 browserHistory 的可能性已被弃用)

关于javascript - React Router - 刷新后保持在同一页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44943920/

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