tree 树形数据,扁平化数组,数组转树形结构父子级数据,模糊搜索,筛选

2024-02-29 11:36

本文主要是介绍tree 树形数据,扁平化数组,数组转树形结构父子级数据,模糊搜索,筛选,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 概要
    • 整体架构流程
    • 小结

概要

提示:树形数据搜索,筛选

整体架构流程

提示:根据搜索条件筛选树形数据
区域IsCheck固定为false,通过判断筛选后的数据有无 设备子级 再进行筛选
树形数据:

var tree = [{id: '01',parentId:'#',modeltype:'area',IsCheck :'false',text: '区域1',children: [{id: '011',parentId:'01',modeltype:'area',IsCheck :'false',text: '区域2',children: [{id: '0111',parentId:'001',text: '设备1',modeltype:'meter',IsCheck :'false',children: [],}, {id: '0112',parentId:'001',text: '设备2',modeltype:'meter',IsCheck :'true',children: [],},],}],}]

模糊搜索,子级与其上级,或区域父级

bindHandleTreeData(tree ,'设备1',{ children: "children"; text: "text" })/*** 搜索设备* @param treeData 树形参数* @param searchValue 搜索参数* @param fieldNames 树形数据结构-字段-看需求* @returns*/const bindHandleTreeData: any = (treeData: any,searchValue: any,fieldNames: { children: "children"; text: "text" }) => {if (!treeData || treeData.length === 0) {return [];}const array = [];for (let i = 0; i < treeData.length; i += 1) {if (bindHandleTreeData(treeData[i][fieldNames.children],searchValue,fieldNames).length > 0 ||treeData[i][fieldNames.text].includes(searchValue)) {array.push({...treeData[i],[fieldNames.children]: bindHandleTreeData(treeData[i][fieldNames.children],searchValue,fieldNames),});}}return array;};

树形数据扁平化-转数组(利于筛选)看需求

// 转数组const getArray = (data: any[]) => {var fun = (data: { [x: string]: any }) => {var a: any[] = [];for (var i in data) {var item = data[i];var obj: any = new Object();for (var j in item) {if (j !== "children") {obj[j] = item[j];}}a.push(obj);if (item.children && item.children.length > 0) {a = a.concat(fun(item.children));}}return a;};var list = fun(data);return list;};

将扁平化后的树形数据,转树形结构数据
搜索IsCheck === false

//扁平化数据
let cloneData=getArray(tree)
//筛选符合需求的数据(item.IsCheck === false)
let meterData = cloneData.filter((item) => {return item.IsCheck === false;});
if (meterData.length) {data = getTree(meterData, "#");}//最后结果console.log(data)  /*** 转树形* @param list 扁平化数据* @param parentId 父id 最顶级父id默认 parentId=#* @returns */const getTree = (list: any[], parentId: any) => {let fun = (parentId: any) => {let parent = parentId ? parentId : "#";let b = [];for (let i in list) {let item = list[i];if (item.parent === parent) {item.children = fun(item.id);// 清除无设备 -区域-看需求(不展示无设备子级元素的区域)if (item.children.length === 0 && item.modeltype === "area") {item["disableCheckbox"] = true;item["IsCheck"] = true;} else {b.push(item);}}}return b;};return fun(parentId);};

区域IsCheck固定为false,通过判断筛选后的数据有无 设备子级 再进行筛选
搜索IsCheck === true

 /*** 获取IsCheck === true设备父级* @param list 数据* @param parentId 父id* @returns*/const getTreeBind = (list: any[], parentId: any) => {let b: any[] = [];let fun = (parentId: any) => {let parent = parentId ? parentId : "#";for (let i in list) {let item = list[i];if (parent === item.id) {if (item.parent !== "#") {b.push(item.id);fun(item.parent);} else {b.push(item.id);}}}return b;};return fun(parentId);};
//扁平化数据
let cloneData=getArray(tree)let data: any[] = [];let meter: any[] = [];let data2 = cloneData;let data1 = data2.filter((item) => {// 判断文字if (item.modeltype === "area") {return item.IsCheck === false;} else {return item.IsCheck === true;}});data1.forEach((item) => {if (item.modeltype !== "area") {meter.push(item.id);if (item.parent !== "#") {//搜索父级 getTreeBindlet filterData = getTreeBind(data1, item.parent);meter = concat(meter, filterData);}}});data1 = data1.filter((item) => {return meter.includes(item.id);});if (data1.length !== 0) {data = getTree(data1, "#");}

小结

提示:总结
1、模糊搜索
2、根据需求进行数据处理

这篇关于tree 树形数据,扁平化数组,数组转树形结构父子级数据,模糊搜索,筛选的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/758647

相关文章

使用Vue-ECharts实现数据可视化图表功能

《使用Vue-ECharts实现数据可视化图表功能》在前端开发中,经常会遇到需要展示数据可视化的需求,比如柱状图、折线图、饼图等,这类需求不仅要求我们准确地将数据呈现出来,还需要兼顾美观与交互体验,所... 目录前言为什么选择 vue-ECharts?1. 基于 ECharts,功能强大2. 更符合 Vue

Java如何根据word模板导出数据

《Java如何根据word模板导出数据》这篇文章主要为大家详细介绍了Java如何实现根据word模板导出数据,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... pom.XML文件导入依赖 <dependency> <groupId>cn.afterturn</groupId>

Python实现获取带合并单元格的表格数据

《Python实现获取带合并单元格的表格数据》由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,所以本文我们就来聊聊如何使用Python实现获取带合并单元格的表格数据吧... 由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,现将将封装成类,并通过调用list_exc

Mysql数据库中数据的操作CRUD详解

《Mysql数据库中数据的操作CRUD详解》:本文主要介绍Mysql数据库中数据的操作(CRUD),详细描述对Mysql数据库中数据的操作(CRUD),包括插入、修改、删除数据,还有查询数据,包括... 目录一、插入数据(insert)1.插入数据的语法2.注意事项二、修改数据(update)1.语法2.有

SpringBoot实现接口数据加解密的三种实战方案

《SpringBoot实现接口数据加解密的三种实战方案》在金融支付、用户隐私信息传输等场景中,接口数据若以明文传输,极易被中间人攻击窃取,SpringBoot提供了多种优雅的加解密实现方案,本文将从原... 目录一、为什么需要接口数据加解密?二、核心加解密算法选择1. 对称加密(AES)2. 非对称加密(R

详解如何在SpringBoot控制器中处理用户数据

《详解如何在SpringBoot控制器中处理用户数据》在SpringBoot应用开发中,控制器(Controller)扮演着至关重要的角色,它负责接收用户请求、处理数据并返回响应,本文将深入浅出地讲解... 目录一、获取请求参数1.1 获取查询参数1.2 获取路径参数二、处理表单提交2.1 处理表单数据三、

MySQL中like模糊查询的优化方案

《MySQL中like模糊查询的优化方案》在MySQL中,like模糊查询是一种常用的查询方式,但在某些情况下可能会导致性能问题,本文将介绍八种优化MySQL中like模糊查询的方法,需要的朋友可以参... 目录1. 避免以通配符开头的查询2. 使用全文索引(Full-text Index)3. 使用前缀索

Spring Validation中9个数据校验工具使用指南

《SpringValidation中9个数据校验工具使用指南》SpringValidation作为Spring生态系统的重要组成部分,提供了一套强大而灵活的数据校验机制,本文给大家介绍了Spring... 目录1. Bean Validation基础注解常用注解示例在控制器中应用2. 自定义约束验证器定义自

C#实现高性能Excel百万数据导出优化实战指南

《C#实现高性能Excel百万数据导出优化实战指南》在日常工作中,Excel数据导出是一个常见的需求,然而,当数据量较大时,性能和内存问题往往会成为限制导出效率的瓶颈,下面我们看看C#如何结合EPPl... 目录一、技术方案核心对比二、各方案选型建议三、性能对比数据四、核心代码实现1. MiniExcel

SQL常用操作精华之复制表、跨库查询、删除重复数据

《SQL常用操作精华之复制表、跨库查询、删除重复数据》:本文主要介绍SQL常用操作精华之复制表、跨库查询、删除重复数据,这些SQL操作涵盖了数据库开发中最常用的技术点,包括表操作、数据查询、数据管... 目录SQL常用操作精华总结表结构与数据操作高级查询技巧SQL常用操作精华总结表结构与数据操作复制表结