js递归展开树形数据

        let navigation = [{
            id: 1,
            subitems: [{
                id: 2,
                subitems: [{
                    id: 3,
                    subitems: [],
                    parent: 2
                },
                {
                    id: 4,
                    subitems: [],
                    parent: 2
                }
                ],
                parent: 1
            },
            {
                id: 5,
                subitems: [],
                parent: 1
            }
            ]
        },
        {
            id: 6,
            subitems: []
        }
        ];

        function flatten(array) {
            return [].concat(...array.map(item => [].concat(item, ...flatten(item.subitems))))
        }
        navigation = flatten(navigation)

        console.log("navigation", navigation);

在这里插入图片描述

        let arr = [{
            id: 1,
            text: "Folder1",
            iconCls: "icon-save",
            children: [{
                text: "File1",
                checked: true
            }, {
                text: "Books",
                state: "open",
                attributes: {
                    url: "/demo/book/abc",
                    price: 100
                },
                children: [{
                    text: "PhotoShop",
                    checked: true
                }, {
                    id: 8,
                    text: "Sub Bookds",
                    state: "closed"
                }]
            }]
        }, {
            text: "Languages",
            state: "closed",
            children: [{
                text: "Java"
            }, {
                text: "C#"
            }]
        }]

        let result = []

        function getId(arr) {
            arr.forEach(v => {
                result.push(v);
                if (v.children instanceof Array) {
                    getId(v.children)
                }
            });
        }
        getId(arr)
        console.log(result);

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值