【发布时间】:2018-02-03 06:44:30
【问题描述】:
我正在使用 React-Router 4 创建一些路由。 (它使用来自official docs 的PrivateRoute 组件,但这与这个问题无关。)
<HashRouter>
<Switch>
<PrivateRoute exact path='/' component={Wrapper(Home)} />
<Route exact path='/login' render={(props) => <Login authenticate={this.authenticate} {...props} />} />
<PrivateRoute exact path='/clients' component={Wrapper(Clients)} />
</Switch>
</HashRouter>
如您所见,Home 和 Clients 组件封装在 HOC 中。目前这没有任何作用:
const Wrapper = (Page) => {
return (props) => (
<div className="page">
<p>This should be on every page</p>
<Page {...props} />
</div>
);
}
这很好用。我想不通的是如何将 Login 路由包装在同一个 HOC 中。我试过了
<Route exact path='/login' render={(props) => Wrapper(<Login authenticate={this.authenticate} {...props} />)} />
但这会返回错误:
Route.render():必须返回一个有效的 React 元素(或 null)。
【问题讨论】:
标签: javascript reactjs react-router higher-order-components