我最初使用hashHistory
从react-router
,并以编程方式导航使用this.props.history.push()
的我的React应用程序。但随着从react-router-dom
包使用HashRouter
,this.props.history.push()
现在抛出Cannot read property 'push' of undefined
错误。以编程方式导航w/HashRouter
如何现在使用HashRouter
以编程方式导航?
ReactDOM.render(
<Provider store={store}>
<MuiThemeProvider>
<HashRouter>
<div>
<Route exact path="/" component={App} />
<Route path="/landing" component={Landing} />
</div>
</HashRouter>
</MuiThemeProvider>
</Provider>,
document.getElementById('root'));
渲染App.js的FUNC
render() {
return (
<div className="App">
...
<div>
<Collapse isOpened={this.state.activeForm === 1}>
<SignUpForm />
</Collapse>
<Collapse isOpened={this.state.activeForm === 2}>
<SignInForm />
</Collapse>
...
</div>
);
}
功能的SignUpForm.js说的呼唤.push()
handleSubmit(e) {
...
this.props.history.push('/landing');
...
}
''history.push()'仍然存在于react-router v4中。但可能无法使用,具体取决于您在何处使用以及如何配置路线。如果您可以分享更多解释这些内容的代码,我们可能会给您一个可靠的答案。 –
@TharakaWijebandara,只是增加了相关的代码。 – Mike
您在哪里尝试在Landing组件内使用'this.props.history.push()'? –