树结构的数据扁平化

javascript 复制代码
function flattenTree(data) {
    data = JSON.parse(JSON.stringify(data));
    var res = [];
    while(data.length) {
        var node = data.shift();
        if (node.children && node.children.length) {
            data = data.concat(node.children);
        }
        delete node.children;
        res.push(node);
    }
    return res;
}

我们用一个数据来测试:

javascript 复制代码
var tree = [{
    id: 1,
    name: '1',
    children: [{
        id: 2,
        name: '2',
        children: [{
            id: 3,
            name: '3',
            children: [{
                id: 4,
                name: '4'
            }]
        }, {
            id: 6,
            name: '6'
        }]
    }]
}, {
    id: 5,
    name: '5'
}]

使用:

javascript 复制代码
console.log(flattenTree(tree));

打印结果:

相关推荐
进击的野人19 小时前
Vue Router 深度解析:从基础概念到高级应用实践
前端·vue.js·前端框架
北慕阳19 小时前
健康管理前端记录
前端
1024小神19 小时前
cloudflare的worker中的Environment环境变量和不同环境配置
前端
栀秋66619 小时前
从零开始调用大模型:使用 OpenAI SDK 实现歌词生成,手把手实战指南
前端·llm·openai
l1t19 小时前
DeepSeek总结的算法 X 与舞蹈链文章
前端·javascript·算法
智航GIS19 小时前
6.2 while循环
java·前端·python
2201_7578308719 小时前
AOP核心概念
java·前端·数据库
雪人.19 小时前
JavaWeb经典面试题
java·服务器·前端·java面试题
JIngJaneIL19 小时前
基于java+ vue学生成绩管理系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端
小恒恒19 小时前
2025 Vibe Coding 有感
前端·uni-app·trae