高阶组件中的withRouter
, 作用是将一个组件包裹进Route
里面, 然后react-router
的三个对象history, location, match
就会被放进这个组件的props
属性中.
// withRouter实现原理:
// 将组件包裹进 Route, 然后返回
// const withRouter = () => {
// return () => {
// return <Route component={Nav} />
// }
// }
// 这里是简化版
const withRouter = ( Component ) => () => <Route component={ Component }/>
上面是实现的原理, react-router-dom
里面是有这个组件的, 直接引入使用就可以了
import React from 'react'
import './nav.css'
import {
NavLink,
withRouter
} from "react-router-dom"
class Nav extends React.Component{
handleClick = () => {
// Route 的 三个对象将会被放进来, 对象里面的方法可以被调用
console.log(this.props);
}
render() {
return (
<div className={'nav'}>
<span className={'logo'} onClick={this.handleClick}>掘土社区</span>
<li><NavLink to="/" exact>首页</NavLink></li>
<li><NavLink to="/activities">动态</NavLink></li>
<li><NavLink to="/topic">话题</NavLink></li>
<li><NavLink to="/login">登录</NavLink></li>
</div>
);
}
}
// 导出的是 withRouter(Nav) 函数执行
export default withRouter(Nav)
所以withRouter
的作用就是, 如果我们某个东西不是一个Router
, 但是我们要依靠它去跳转一个页面, 比如点击页面的logo
, 返回首页, 这时候就可以使用withRouter
来做.
在这个例子中, 我将span
使用withRouter
作为一个可点击跳转的Link