递归算法通过子节点查找当前节点的父节点。

实际场景为, 你已经获取到某一个确认的子 id ,想找到其上一级,增加一个对象或者删除一个对象。

直接干代码

var arr =
    {
        id: 0, name: '000', children:
            [
                {
                    id: 1, name: "xhh", children: [
                        {
                            id: 11, name: "xx", children: [
                                { id: 111, name: "111", children: [] },
                                { id: 112, name: "112", children: [] },
                                { id: 112, name: "112", children: [] }
                            ]
                        }
                    ]
                },
                {
                    id: 2, name: "xhh", children: [
                        {
                            id: 21, name: "21", children: [
                                { id: 221, name: "221", children: [] },
                                { id: 222, name: "222", children: [] },
                                { id: 223, name: "223", children: [] }
                            ]
                        }
                    ]
                },
            ]
    };
//传入参数:需要遍历的json,需要匹配的id
    function findParentNode(data, id) {
        //设置结果
        let result;
        if (!data) {
            return;//如果data传空,直接返回
        }
        for (var i = 0; i < data.children.length; i++) {
            let item = data.children[i];
            if (item.id == id) {
                result = data;
                return result; //这里是实际返回的值,你可以只返回当前对象,或者指定当前对象的某个字段。
            } else if (item.children && item.children.length > 0) {
                //如果有子集,则把子集作为参数重新执行本方法
                result = findParentNode(item, id);
                //关键,千万不要直接return本方法,不然即使没有返回值也会将返回return,导致最外层循环中断,直接返回undefined,要有返回值才return才对
                if (result) {
                    return result;
                }
            }
        }
        //如果执行循环中都没有return,则在此return
        return result;
    }

测试删除当前节点 223 为实际需求已经获取的节点id

var nodeEl = findParentNode(arr, 223);
    console.log(nodeEl)

    nodeEl.children.forEach((item, index) => {
        if (item.id == 223) {
            nodeEl.children.splice(index, 1);
        }
    })

    console.log(nodeEl.children)	// 这里的元素已经删除了, 并且原数组arr 也删掉了,原理是JS的深浅拷贝。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

__不靠谱先生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值