【发布时间】:2018-07-09 20:09:09
【问题描述】:
一个非常简单的应用程序。在/ 路径上,我想在登录时呈现Home,如果未登录,则呈现Introduction。在登录页面上登录有效,如果我 console.log(firebase.auth().currentUser) 它显示所有数据和/ 正确呈现Home。因此,虽然仍在/ 路径上,但发生了一些奇怪的事情;当我刷新页面时,我们不再登录,它呈现Introduction。但是当我单击链接<li><Link to='/'>Home</Link></li> 时,Home 组件会正确呈现,并且我们会再次登录。为什么会这样?
import React, { Component } from 'react';
import {BrowserRouter as Router, Route, Switch, Link, Redirect} from 'react-router-dom';
import firebase from './firebase'
import Home from './containers/home'
import Login from './containers/login'
import Register from './containers/register'
import Dashboard from './containers/dashboard'
const Protected = ({component: Component, ...rest}) => (
<Route {...rest} render={(props) => {
if(firebase.auth().currentUser)
return <Component {...props} />
else
return <Redirect to='/register' />
}} />
)
const Introduction = props => ( <h1>hello</h1>)
class App extends Component {
render() {
return (
<Router>
<React.Fragment>
<ul>
<li><Link to='/'>Home</Link></li>
<li><Link to='/register'>Register</Link></li>
<li><Link to='/login'>login</Link></li>
<li><Link to='/dashboard'>dashboard</Link></li>
</ul>
<Switch>
<Route path='/' exact render={(props) => {
if(firebase.auth().currentUser)
return <Home {...props} />
else
return <Introduction {...props} />
}
} />
<Route path='/register' exact component={Register} />
<Route path='/login' component={Login} />
<Protected path='/dashboard' component={Dashboard} />
</Switch>
</React.Fragment>
</Router>
);
}
}
export default App;
【问题讨论】:
标签: javascript reactjs firebase react-router firebase-authentication