《CMS后台系统》项目实战 详细分解(六)

简介: 《CMS后台系统》项目实战 详细分解(六)

点击实现路由跳转

  • 修改key值
<Menu.Item key="list"><ReadOutlined /> 查看文章列表</Menu.Item>
      <Menu.Item key="edit"><EditOutlined /> 文章编辑</Menu.Item>
      <Menu.Item key="means"><DatabaseOutlined /> 修改资料</Menu.Item>
复制代码


  • 使用hook跳转
import {useNavigate} from 'react-router-dom'
  const navigate = useNavigate()
复制代码


// 修改handleClick
  const handleClick = e => {
    navigate('/'+e.key)
  };
复制代码


// 默认路由
  defaultSelectedKeys={['list']}
复制代码


QQ截图20221112082042.png


  • 实现效果

微信截图_20221112082418.png


遇到的bug

刷新之后路径并未改变,菜单栏改变了。

微信截图_20221112082439.png


  • 片段代码

引入useLocation

import React, { useEffect, useState } from 'react'
import {useNavigate, useLocation} from 'react-router-dom'
const location = useLocation()
const [defaultKey, setDefaultKey] = useState('')
// 一旦渲染立刻获取动态的路由路径,不在使用默认的
  useEffect(() => {
      let path = location.pathname;
      let key = path.split('/')[1];
      setDefaultKey(key)
  }, []);
  // 及时更新路由路径
    const handleClick = e => {
    navigate('/'+e.key)
    setDefaultKey(e.key)
  };
复制代码


  • 实现效果图(自己刷新试试咯)

微信截图_20221112082458.png


微信截图_20221112082517.png


面包屑

传送门

ant.design/components/…

  • 创建Bread组件

微信截图_20221112082540.png


初始化书写Bread组件

import React from 'react';
import { Breadcrumb } from 'antd';
import { HomeOutlined } from '@ant-design/icons';
const Bread = () => {
    return (
        <Breadcrumb>
        <Breadcrumb.Item href="">
          <HomeOutlined />
        </Breadcrumb.Item>
        <Breadcrumb.Item>Application</Breadcrumb.Item>
      </Breadcrumb>
    );
}
export default Bread;
复制代码


在App组件中引入一个Bread组件

import Bread from './components/Bread'
<div className='container_box'>
    <Bread/>
      <Outlet/>   
</div>
复制代码


  • 根据路径更新面包屑

更新面包屑名字(useEffect取过来,useState再赋值更新上)

// 引入hook
import React, {useState,useEffect} from 'react';
// 设置变量
const [breadName, setBreadName] = useState('')
// 获取路径
const {pathname} = useLocation()
// 不是在组件mounted时去获取路径,而是路径一旦变化,就要获取对应的路径名称,并且修改breadName
// 监听路由的路径(/list /edit /means)
useEffect(() => {
    switch (pathname) {
        case "/list":
            setBreadName('查看文章列表');
            break;
        case "/edit":
            setBreadName('文章编辑');
            break;
        case "/means":
            setBreadName('修改资料');
            break;
        default:
            break;
    }
}, [pathname])
复制代码


内容补充(表单,表格)

  • 创建2个路由组件

微信截图_20221112082617.png

微信截图_20221112082632.png


  • 配置路由(index.jsx)
import ListTable from '../pages/ListTable'
import ListList from '../pages/ListList'
const BaseRouter = () => (
    <Router>
        <Routes>
            <Route path='/' element={<App />}>
                <Route path='/listtable' element={<ListTable />}></Route>
                <Route path='/listlist' element={<ListList />}></Route>
                <Route path='/edit' element={<Edit />}></Route>
                <Route path='/means' element={<Means />}> </Route>
            </Route>
            <Route path='/login' element={<Login />}> </Route>
            <Route path='/register' element={<Register />}> </Route>
        </Routes>
    </Router>
)
复制代码


  • 修改面包屑
useEffect(() => {
        switch (pathname) {
            case "/listlist":
                setBreadName('查看文章列表List');
                break;
            case "/listtable":
                setBreadName('查看文章列表Table');
                break;
            case "/edit":
                setBreadName('文章编辑');
                break;
            case "/means":
                setBreadName('修改资料');
                break;
            default:
                setBreadName(pathname.includes('edit') ? '文章编辑' : "");
                break;
        }
    }, [pathname])
复制代码


  • 修改侧边栏
<Menu.Item key="listlist"><ReadOutlined /> 查看文章列表List</Menu.Item>
            <Menu.Item key="listtable"><ReadOutlined /> 查看文章列表Table</Menu.Item>
复制代码


  • 实现效果

微信截图_20221112082656.png


ListTable 书写样式

  • 在APP组件中设置布局属性
<div className='container_box'>
    <Bread/>
      <Outlet/>   
</div>
复制代码


base.less

.container .container_box {
  flex: 1;
  box-sizing: border-box;
  padding: 20px;
  display: flex;
  flex-direction: column;
}
复制代码


  • 创建less文件

微信截图_20221112082715.png


.list_table{
    width: 100%;
    background: #fff;
    height: 100%;
}
复制代码


  • 引入less样式到ListTable
import './less/ListTable.less'
// 不要忘记添加类名
<div className='list_table'>ListTable</div>
复制代码


  • 实现效果图

微信截图_20221112082731.png



目录
相关文章
|
1月前
|
自然语言处理 前端开发 安全
CMS网站管理系统的优势及选择。
CMS是内容管理系统,可创建特色网站,实现内容创作、编辑、发布等,支持多用户管理、模板切换、多语言等,常用于企业、商城、论坛等,缩短建站成本和周期。
207 6
|
8月前
|
Python
空间管理大师已上线!(2),Python高级工程师进阶学习】
空间管理大师已上线!(2),Python高级工程师进阶学习】
|
11天前
|
存储 监控 搜索推荐
内容管理系统CMS是什么?全面解读CMS的核心功能
2分钟了解内容管理系统CMS的主要作用和常见平台。CMS常被用于简化内容管理流程,提高内容发布效率。
94 7
内容管理系统CMS是什么?全面解读CMS的核心功能
|
数据库
【自然框架】CMS之数据库设计
    在园子里也混了三年多,随笔200多,一开始只是想把自己的经验写一下,后来呢弄出来了一个“自然框架”,主要精力就放在了介绍自然框架的思路上面了。随笔多了就发现一个问题:有点乱。虽然博客有分组,但是只支持一级分组,不支持n级的。
1612 0
|
小程序 前端开发 Java
毕业设计-基于微信小程序的智能垃圾分类回收系统
毕业设计-基于微信小程序的智能垃圾分类回收系统
|
小程序 数据可视化 数据库
云开发(微信-小程序)笔记(十七)---- cms(内容管理)及案例
云开发(微信-小程序)笔记(十七)---- cms(内容管理)及案例
557 0
|
搜索推荐 数据库 Nacos
项目实战典型案例8——让软件的使用者成为软件的设计者
项目实战典型案例8——让软件的使用者成为软件的设计者
137 0
|
数据库 Nacos
【项目实战典型案例】08.用户成为设计者的正例
【项目实战典型案例】08.用户成为设计者的正例
|
存储
《CMS后台系统》项目实战 详细分解(五)
《CMS后台系统》项目实战 详细分解(五)
103 0
《CMS后台系统》项目实战 详细分解(五)
《CMS后台系统》项目实战 详细分解(八)
《CMS后台系统》项目实战 详细分解(八)
129 0
《CMS后台系统》项目实战 详细分解(八)