Ai
5 Star 145 Fork 109

react-cp/react-pc-code

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
index.js 2.50 KB
一键复制 编辑 原始数据 按行查看 历史
柴鹏 提交于 2022-05-18 13:38 +08:00 . fixed bug
import { Layout, Menu, Popconfirm } from 'antd'
import { Outlet, Link, useLocation, useNavigate } from 'react-router-dom'
import { observer } from 'mobx-react-lite'
import {
HomeOutlined,
DiffOutlined,
EditOutlined,
LogoutOutlined
} from '@ant-design/icons'
import './index.scss'
import { useStore } from '@/store'
import { useEffect } from 'react'
const { Header, Sider } = Layout
const GeekLayout = () => {
const { pathname } = useLocation()
const { userStore, loginStore, channelStore } = useStore()
useEffect(() => {
userStore.getUserInfo()
channelStore.loadChannelList()
}, [userStore, channelStore])
// 确定退出
const navigate = useNavigate()
const onConfirm = () => {
// 退出登录 删除token 跳回到登录
loginStore.loginOut()
navigate('/login')
}
return (
<Layout>
<Header className="header">
<div className="logo" />
<div className="user-info">
<span className="user-name">{userStore.userInfo.name}</span>
<span className="user-logout">
<Popconfirm
onConfirm={onConfirm}
title="是否确认退出?" okText="退出" cancelText="取消">
<LogoutOutlined /> 退出
</Popconfirm>
</span>
</div>
</Header>
<Layout>
<Sider width={200} className="site-layout-background">
{/* 高亮原理:defaultSelectedKeys === item key */}
{/* 获取当前激活的path路径? */}
{/*
defaultSelectedKeys: 初始化渲染的时候生效一次
selectedKeys: 每次有值更新时都会重新渲染视图
*/}
<Menu
mode="inline"
theme="dark"
defaultSelectedKeys={pathname}
selectedKeys={pathname}
style={{ height: '100%', borderRight: 0 }}
>
<Menu.Item icon={<HomeOutlined />} key="/">
<Link to='/'>数据概览</Link>
</Menu.Item>
<Menu.Item icon={<DiffOutlined />} key="/article">
<Link to="/article">内容管理</Link>
</Menu.Item>
<Menu.Item icon={<EditOutlined />} key="/publish">
<Link to='/publish'> 发布文章</Link>
</Menu.Item>
</Menu>
</Sider>
<Layout className="layout-content" style={{ padding: 20 }}>
{/* 二级路由出口 */}
<Outlet />
</Layout>
</Layout>
</Layout>
)
}
export default observer(GeekLayout)
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/react-cp/react-pc-code.git
git@gitee.com:react-cp/react-pc-code.git
react-cp
react-pc-code
react-pc-code
master

搜索帮助