所以<Link />
处理路由器导航的 onClick 的实现很简单:
const { history } = this.context.router;
history.push(to);
所以在我的应用程序中它应该可以工作,因为上下文是从<Router>
组件传递下来的,对吗?
class App extends React.Component {
constructor() {
super(...arguments);
}
render() {
const home = () => (<div>Home</div>);
const about = () => (<div>About</div>);
const { history } = this.context.router;
console.log("History", history);
return (
<div>
<ul>
<li><Link to="/">Home</Link></li>
<li><Link to="/about">About</Link></li>
</ul>
<Route exact path="/" component={home} />
<Route path="/about" component={about} />
</div>
)
}
}
ReactDOM.render(
<Router>
<App />
</Router>,
document.getElementById('main')
);
但正如您在控制台输出中看到的那样,历史对象是未定义的......