const rootEl = document.getElementById('root');
ReactDOM.render(
<BrowserRouter>
<Switch>
<Route exact path="/">
<MasterPage />
</Route>
<Route exact path="/details/:id" >
<DetailsPage />
</Route>
</Switch>
</BrowserRouter>,
rootEl
);
Ich versuche, auf die ID in der DetailsPage-Komponente zuzugreifen, aber es ist nicht zugänglich. Ich habe es versucht
<DetailsPage foo={this.props}/>
Parameter an die DetailsPage zu übergeben, aber vergebens.
export default class DetailsPage extends Component {
constructor(props) {
super(props);
}
render() {
return (
<div className="page">
<Header />
<div id="mainContentContainer" >
</div>
</div>
);
}
}
Haben Sie also eine Idee, wie Sie die ID an die Detailseite weitergeben können?
quelle
<Route exact path="/details/:id" ><DetailsPage /></Route>
war nicht dasselbe wie<Route exact path="/details/:id" component={DetailsPage} />
. Ihr Code wurdeDetailsPage
auch dann gerendert , wenn Sie '/' besucht haben. Zweitens, als Sie geschrieben haben<DetailsPage foo={this.props}/>
,this
verwiesennull
. Deshalb hat es nicht funktioniert.Warning: [react-router] You cannot change <Router routes>; it will be ignored