gpt4 book ai didi

javascript - React Router with Private Route 呈现空白页面

转载 作者:行者123 更新时间:2023-11-30 19:45:41 25 4
gpt4 key购买 nike

已阅读所有相关主题,但仍未找到答案

大家好,

我的代码中有一个错误,而且我一如既往地找不到它,所以请帮助我找到让它工作的方法。

我有 create-react-app,我正在尝试添加用户身份验证。我正在查看的教程:http://jasonwatmore.com/post/2018/09/11/react-basic-http-authentication-tutorial-example

问题: 当我登录时,我看到“仪表板”(准确)组件,一切正常。但是后来我点击了其他链接,比如“订单”等。我得到了空白页面。控制台上没有错误。

让我们从头开始。

index.js

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';

import { configureFakeBackend } from './_helpers/fake-backend';
configureFakeBackend();

ReactDOM.render((
<App />
), document.getElementById('root'));

App.js 文件

import React, { Component } from 'react';
import './App.scss';
import MainContent from './components/MainContent.jsx';
import { BrowserRouter as Router, Route, Switch } from 'react-router-dom';
import { PrivateRoute } from './components/PrivateRoute';
import { LoginPage } from './LoginPage/LoginPage';


class App extends Component {
render() {
return (
<Router>
<Switch>
<PrivateRoute exact path="/" component={MainContent} />
<Route path="/login" component={LoginPage} />
</Switch>
</Router>
);
}
}

export default App;

PrivateRoute.jsx

import React from 'react';
import { Route, Redirect } from 'react-router-dom';

export const PrivateRoute = ({ component: Component, ...rest }) => (
<Route {...rest} render={props => (
localStorage.getItem('user')
? <Component {...props} />
: <Redirect to={{ pathname: '/login', state: { from: props.location } }} />
)} />
)

MainContent.jsx

import React, { Component } from 'react';
import Sidebar from './Sidebar.jsx';
import Header from './Header.jsx';
import Main from './Main.jsx';
import { userService } from '../_services/user.service';
import { Link } from 'react-router-dom';

class MainContent extends Component {
constructor(props) {
super(props);

this.state = {
user: {},
users: []
};
}
componentDidMount() {
this.setState({
user: JSON.parse(localStorage.getItem('user')),
users: { loading: true }
});
userService.getAll().then(users => this.setState({ users }));
}
render() {
const { user, users } = this.state;
return (

<React.Fragment>
<h1>Hi {user.firstName}!</h1>
{users.loading && <em>Loading users...</em>}
{users.length &&
<ul>
{users.map((user, index) =>
<li key={user.id}>
{user.firstName + ' ' + user.lastName}
</li>
)}
</ul>
}
<p>
<Link to="/login">Logout</Link>
</p>
<Sidebar />
<div id="flexing">
<Header />
<Main />
</div>
</React.Fragment>
);
}
}

export default MainContent;

至少:Main.jsx

import React from 'react';
import { Switch, Route } from 'react-router-dom';
import Dashboard from './Dashboard';
import Orders from './Orders';
import Routes from './Routes';
import Drivers from './Drivers';
import Settings from './Settings';

const Main = () => (
<main>
<Switch>
<Route exact path='/' component={Dashboard}/>
<Route path='/orders' component={Orders}/>
<Route path='/routes' component={Routes}/>
<Route path='/drivers' component={Drivers}/>
<Route path='/settings' component={Settings}/>
</Switch>
</main>
);

export default Main;

所以 Dashboard 组件将呈现良好,但其他组件呈现为空白页面。请帮助修复它。等待回复。

贾斯塔斯

最佳答案

没错,Main.js 中的那些路由仅在 App.js 呈现时才呈现。即当路径为/时,渲染Main.js。如果是其他情况,则不会呈现 Main.js,因此永远不会命中 Switch 组件。

要解决它,您应该删除 Main.js 并将所有这些路由放在顶层(如果有帮助,您可以在 App.js 中有两个 Switch 组件),或者设置App.js 中的路径(对于 MainComponent)以包含所有这些。前者更干净,因为后者可能会变得复杂。

要确定这是问题所在,请将默认路由添加到 App.js,您会看到您看到的“空白”页面是因为在该级别没有任何匹配项;要设置默认值,请在 * 上匹配路径。

关于javascript - React Router with Private Route 呈现空白页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54973760/

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