软件教程 2025年08月6日
0 收藏 0 点赞 811 浏览 2830 个字
摘要 :

文章目录 前言 树状转扁平数据 方法一 方法二 方法三 扁平数据转树状 方法一 方法二 本文主要讲解关于JS实现扁平数据和树状数据相互转换相关内容,让我们来一起学习……




  • 前言
  • 树状扁平数据
    • 方法一
    • 方法二
    • 方法三
  • 扁平数据转树状
    • 方法一
    • 方法二

    本文主要讲解关于JS实现扁平数据和树状数据相互转换相关内容,让我们来一起学习下吧!

    前言

    平时处理数据就经常要处理树状和平面结构数据的转化,所以就写来记一下,方便下次用直接copy,用的都是比较笨重的方法,大家要是还有其他好的方法可以分享就太感谢了

    树状转扁平数据

    方法一

    正向深入,顺着树的方向一级级下钻,先讲父级元素添加到准备号的数组里面,如果有子级就继续深下直到不能下去
    得到的数据就是顺着树方向来的,得到的数据大概是这样子的1_1,1_1_1,1_1_2,…(也可以反向下钻,将resultArr.push(val)语句放到判断的后面,得到的顺序大概是这样的1_1_1,1_1_2,1_1…)

            const arr = [
            {
                id: \'1\',
                name: \'1_1\',
                children: [
                    { id: \'a\', name: \'1_1_1\' },
                    { id: \'b\', name: \'1_1_2\' },
                ]
            },
            {
                id: \'2\',
                name: \'2_2\',
                children: [
                    { id: \'a\', name: \'2_2_2\' }
                ]
            }
        ]
        const resultArr = []
        function treeToData(data) {
           data.map(val => {
                resultArr.push(val)
                if (val.children && val.children.length > 0) {
                    treeToData(val.children)
                    delete val.children
                }
            })
    
            return resultArr;
        }
        console.log(treeToData(arr));
        
        
    

    方法二

    使用reduce的累加,将遍历好的数据放在account里面,一开始account没有数据,所以是空数组,将当前的数据添加进来,判断有没有子级,有就递归调用方法,将返回来的数据合并

      const arr = [
            {
                id: \'1\',
                name: \'1_1\',
                children: [
                    { id: \'a\', name: \'1_1_1\' },
                    { id: \'b\', name: \'1_1_2\' },
                ]
            },
            {
                id: \'2\',
                name: \'2_2\',
                children: [
                    { id: \'a\', name: \'2_2_2\' }
                ]
            }
        ]
        function treeToData(data, parentId = null) {
            return data.reduce((account, current) => {
                account.push({ ...current, parentId })
                if (current.children) {
                    account = account.concat(treeToData(current.children, current.id))
                }
                return account
            }, [])
    
        }
        console.log(treeToData(arr));
        
    

    方法三

    方法三和方法二比较像,只是换一种遍历

      const arr = [
            {
                id: \'1\',
                name: \'1_1\',
                children: [
                    { id: \'a\', name: \'1_1_1\' },
                    { id: \'b\', name: \'1_1_2\' },
                ]
            },
            {
                id: \'2\',
                name: \'2_2\',
                children: [
                    { id: \'a\', name: \'2_2_2\' }
                ]
            }
        ]
        function treeToData(data, parentId = null) {
            let resultArr = []
            for (let i = 0; i < data.length; i++) {
                resultArr.push({ ...data[i], parentId }) 
                if (data[i].children) {
                    resultArr = resultArr.concat(treeToData(data[i].children, data[i].id))
                }
    
            }
    
            return resultArr
    
        }
        console.log(treeToData(arr));
        
    

    扁平数据转树状

    方法一

    先判断是不是父级,定义一个中间变量存储该数据,如果是就递归拿到所有的子级挂载在这个临时变量上,最后将临时变量添加到最终结果上

        const arr = [
            { id: \'1\', name: \'1_1\', parentId: null },
            { id: \'2\', name: \'1_1_1\', parentId: \'1\' },
            { id: \'2\', name: \'1_1_2\', parentId: \'1\' },
            { id: \'3\', name: \'1_2\', parentId: null },
            { id: \'4\', name: \'1_2_1\', parentId: \'3\' },
            { id: \'5\', name: \'1_2_1_1\', parentId: \'4\' }
        ]
    
        function dataToTree(data, parentId) {
            const resultArr = []
            let temp;
            for (let i = 0; i < data.length; i++) {
                if (data[i].parentId === parentId) {
                    const obj = data[i];
                    temp = dataToTree(data, data[i].id);
                    if (temp.length > 0) {
                        obj.children = temp;
                    }
                    resultArr.push(obj);
                }
            }
            return ersultArr;
        }
        console.log(dataToTree(arr, null));
        
    

    方法二

    使用 filter() 函数过滤出所有的父节点,,再使用map去构造子节点,并且递归填充子节点

          const arr = [
            { id: \'1\', name: \'1_1\', parentId: null },
            { id: \'2\', name: \'1_1_1\', parentId: \'1\' },
            { id: \'2\', name: \'1_1_2\', parentId: \'1\' },
            { id: \'3\', name: \'1_2\', parentId: null },
            { id: \'4\', name: \'1_2_1\', parentId: \'3\' },
            { id: \'5\', name: \'1_2_1_1\', parentId: \'4\' }
        ]
       function dataToTree(data, parentId) {
            const children = data.filter(val => val.parentId === parentId)
    
            if (!children) {
                return null
            }
    
            return children.map(item => (
                {
                    ...item,
                    children: dataToTree(data, item.id)
                }
            ));
        }
        console.log(dataToTree(arr, null));
    

    以上就是关于JS实现扁平数据和树状数据相互转换相关的全部内容,希望对你有帮助。欢迎持续关注潘子夜个人博客(www.panziye.com),学习愉快哦!

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/6621.html

管理员

相关推荐
2025-08-06

文章目录 一、Promise基础回顾 二、Promise 与 axios 结合使用场景及方法 (一)直接返回 axios …

269
2025-08-06

文章目录 一、模块初始化时的内部机制 二、常见导出写法的差异分析 (一)写法一:module.exports…

107
2025-08-06

文章目录 一、ResizeObserver详解 (一)ResizeObserver是什么 (二)ResizeObserver的基本用法 …

683
2025-08-06

文章目录 一、前期准备工作 (一)下载相关文件 (二)安装必要工具 二、处理扣子空间生成的文件…

338
2025-08-06

文章目录 一、官方文档 二、自动解包的数据类型 ref对象:无需.value即可访问 reactive对象:保持…

371
2025-08-06

文章目录 一、Hooks的工作原理 二、在if语句中使用Hook会出什么岔子? 三、React官方的Hook使用规…

843
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号