封装withRouter高阶组件

import {useNavigate,useLocation,useSearchParams,useParams} from 'react-router-dom'


function withRouter(WrapComponent){
const navigate = useNavgiate()
const location = useLocation()
const [searchParams] = useSearchParams()
const params = useParams()

return function(props){

        return <WrapComponent {...props} navigate={navigate } location={location } query={searchParams} params={params }>

</WrapComponent>

}

}

export default withRouter

Home组件:

import React, { useState, useEffect } from 'react'
import { Outlet} from 'react-router-dom'
import {useSelector,useDispatch} from 'react-redux'
import { Layout,Menu } from 'antd'
import {getMenusAsync,getRoutesAsync} from '../../redux/modules/loginRedux'
import '../../assets/css/home.scss'
import withRouter from '../../hoc/withRouter'

const {Header,Footer,Sider,Content} = Layout
function Home(props) {
    const [img, SetImg] = useState('')
    const dispatch = useDispatch()

    useEffect(() => {
        const img = require('../../assets/logo.png')
        SetImg(img)
        dispatch(getMenusAsync)
        dispatch(getRoutesAsync)
    },[])
    // 获取菜单
    const menus = useSelector((state)=>{
            return state.login.menus
    })

    // 路由跳转事件
    const routerJump = (item)=>{ 
        console.log(item);
        props.navigate(item.key)
    }
    return (
        <Layout className='Home-container'>
                <Sider className='Home-container-sider'  style={{backgroundColor:'#404a59'}}>
                    <img src={img} alt="" />
                    <Menu
                    className='Home-container-sider-menu'
                    items={menus}
                    mode='inline'
                    theme='dark'
                    onClick={routerJump}
                    style={{backgroundColor:'#404a59'}}
                    ></Menu>
                </Sider>
            <Layout className='Home-container-right'>
                <Header></Header>
                <Content className='Home-container-content'>
                <Outlet></Outlet>
                </Content>
                <Footer></Footer>
            </Layout>
        </Layout>
    )
}
export default withRouter(Home)

注意:组件中接收到的props是来自高阶组件传递的值

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值