js遍历树形结构并返回所有的子节点id值

场景

很多时候我么需要返回返回tree结构下的所有自己节点
很显然这个时候需要遍历了
废话不多说
直接递归遍历

数据结构

var treeData = [{
        id: 111,
        title: "机构1",
        children: [{
                id: 123,
                title: "机构1",
            },
            {
                id: 11123,
                title: "机构1231",
                children: [{
                    id: 111211231233,
                    title: "机构1231",
                }]
            },
            {
                id: 11121212123,
                title: "机构11111231",
            }
        ]
    },
    {
        id: 1112111113,
        title: "机构1211131",
        children: [{
            id: 1110000211231233,
            title: "机构12300001",
        }]
    },
    {
        id: 110001112113,
        title: "机构1211000111211331",
        children: [{
            id: 11100999911231233,
            title: "机构100002300001",
            children: [{
                id: 100,
                title: "机构l",
            }]
        }]
    },
    {
        id: 9999,
        title: "部门11",
        children: [{
            id: 000233,
            title: "部门31",
            children: [{
                id: 110,
                title: "机2构l",
            }]
        }]
    },
]

我的思路

首先肯定是需要进行循环的,我使用的是for of循环
假设tree数据是一个[{},{}]这样类型的
那么直接将id值push进去就可以了
如果{}中有children这个字段的话
我们需要判断是否有children并且长度是否大于0
if (item.children && item.children.length)
如果有的话
我们需要自己调用自己并且需要传递参数给自己
第一个参数肯定被遍历的值;也就是 item.children
第二个参数是arr,用来需要返回的所有id

返回所有的id值

function lookForAllId(data = [], arr = []) {
    for (let item of data) {
        arr.push(item.id)
        if (item.children && item.children.length) lookForAllId(item.children, arr)
    }
    return arr
}
console.log(lookForAllId(treeData));

还有没有更优秀的写法

明天继续写
posted @   南风晚来晚相识  阅读(4844)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
点击右上角即可分享
微信分享提示