前端基础(三十七):属性结构数据进行关键字筛选

效果

核心源码

ts 复制代码
type MenuItem = {
    label: string;
    key: string | number;
    icon?: React.ReactNode;
    children?: MenuItem[];
    type?: 'group';
}

function filterTreeData(tree: MenuItem[], keyword: string): MenuItem[] {
    return tree.filter((node: MenuItem) => {
        if (node.label.includes(keyword)) {
            return true;
        }
        if (Array.isArray(node.children)) {
            node.children = filterTreeData(node.children, keyword);
            return !!node.children?.length;
        }
        return false;
    });
}

源码

ts 复制代码
import React, {useState} from 'react';
import {
    BarChartOutlined, CompassOutlined, DatabaseOutlined, DeploymentUnitOutlined, DesktopOutlined, SettingOutlined,
    FundProjectionScreenOutlined, FundViewOutlined, HomeOutlined, MenuFoldOutlined, MenuUnfoldOutlined, MessageOutlined,
    TrophyOutlined, VerifiedOutlined,
} from '@ant-design/icons';
import {Flex, Button, Menu as AntdMenu} from 'antd';
import Search from "antd/es/input/Search";
import {SearchProps} from "antd/lib/input";

type MenuItem = {
    label: string;
    key: string | number;
    icon?: React.ReactNode;
    children?: MenuItem[];
    type?: 'group';
}

function getItem(label: React.ReactNode, key: React.Key, icon?: React.ReactNode, children?: MenuItem[], type?: 'group',): MenuItem {
    return {key, icon, children, label, type,} as MenuItem;
}

function filterTreeData(tree: MenuItem[], keyword: string): MenuItem[] {
    return tree.filter((node: MenuItem) => {
        if (node.label.includes(keyword)) {
            return true;
        }
        if (Array.isArray(node.children)) {
            node.children = filterTreeData(node.children, keyword);
            return !!node.children?.length;
        }
        return false;
    });
}

const Menu: React.FC = () => {

    const menuItems: MenuItem[] = [
        getItem('首页', '1', <HomeOutlined/>),
        getItem('平台管理', '2', <DesktopOutlined/>, [
            getItem('学生管理', '2-1'),
            getItem('教师管理', '2-2'),
            getItem('班级管理', '2-3'),
            getItem('任务管理', '2-4', null, [
                getItem('课程管理', '2-4-1'),
                getItem('发布任务', '2-4-2'),
            ]),
            getItem('作业管理', '2-5'),
            getItem('答卷管理', '2-6', null, [
                getItem('批卷列表', '2-6-1'),
                getItem('批卷结果', '2-6-2'),
            ]),
        ]),
        getItem('平台资源', '3', <DatabaseOutlined/>),
        getItem('教学实训', '4', <MessageOutlined/>),
        getItem('培训认证', '5', <VerifiedOutlined/>),
        getItem('技能竞赛', '6', <TrophyOutlined/>),
        getItem('科研实验', '7', <DeploymentUnitOutlined/>),
        getItem('数据平台', '8', <BarChartOutlined/>),
        getItem('算法平台', '9', <FundProjectionScreenOutlined/>),
        getItem('系統管理', '10', <CompassOutlined/>),
        getItem('系统监控', '11', <FundViewOutlined/>),
        getItem('系統工具', '12', <SettingOutlined/>),
    ];

    const [items, setItems] = useState<MenuItem[]>(menuItems);

    const [collapsed, setCollapsed] = useState(false);

    const toggleCollapsed = () => {
        setCollapsed(!collapsed);
    };

    const onSearch: SearchProps['onSearch'] = (value, _e, _info) => {
        setItems(filterTreeData(menuItems, value));
    };

    return (
        <>
            <div className="menu-tool">
                <Flex gap={10}>
                    {collapsed ? '' : (<Search placeholder="在此输入关键词..." onSearch={onSearch}/>)}
                    <Button block={collapsed} type="primary" onClick={toggleCollapsed} icon={collapsed ? <MenuUnfoldOutlined/> : <MenuFoldOutlined/>}/>
                </Flex>
            </div>
            <AntdMenu defaultSelectedKeys={['1']} mode="inline" inlineCollapsed={collapsed} items={items}/>
        </>
    );
};

export default Menu;
相关推荐
匹马夕阳6 分钟前
Vue 3中导航守卫(Navigation Guard)结合Axios实现token认证机制
前端·javascript·vue.js
你熬夜了吗?8 分钟前
日历热力图,月度数据可视化图表(日活跃图、格子图)vue组件
前端·vue.js·信息可视化
Evand J15 分钟前
matlab绘图——彩色螺旋图
开发语言·matlab·信息可视化
深度混淆1 小时前
C#,入门教程(04)——Visual Studio 2022 数据编程实例:随机数与组合
开发语言·c#
雁于飞1 小时前
c语言贪吃蛇(极简版,基本能玩)
c语言·开发语言·笔记·学习·其他·课程设计·大作业
wenxin-2 小时前
NS3网络模拟器中如何利用Gnuplot工具像MATLAB一样绘制各类图形?
开发语言·matlab·画图·ns3·lr-wpan
数据小爬虫@4 小时前
深入解析:使用 Python 爬虫获取苏宁商品详情
开发语言·爬虫·python
健胃消食片片片片4 小时前
Python爬虫技术:高效数据收集与深度挖掘
开发语言·爬虫·python
王老师青少年编程5 小时前
gesp(C++五级)(14)洛谷:B4071:[GESP202412 五级] 武器强化
开发语言·c++·算法·gesp·csp·信奥赛
一只小bit6 小时前
C++之初识模版
开发语言·c++