一维数组处理成拥有children树结构数据

该博客主要介绍了一个JavaScript函数`getTreeData`,用于将数组数据转换为树形结构。通过`arrayToJson`辅助函数,遍历数据并根据`fid`字段构建父子关系。当`fid`在原始数据中找到对应的`id`时,将其作为子节点添加到父节点的`children`数组中,若找不到则作为顶层节点。这个过程有助于组织和展示层级化的数据。
摘要由CSDN通过智能技术生成
function getTreeData(id) {
        var self = this;
        data = [{
            id: "5",
            name: "二级目录0",
            lv: "1",
            catalogs: [],
            fid: "0"
        },{
            id: "8",
            name: "二级目录1",
            lv: "2",
            catalogs: [],
            fid: "5"
        }];
        data = self.arrayToJson(data)
        console.log(self.arrayToJson(data))
    }
    function arrayToJson(treeArray) {
        var res = [];
        var tmpMap = {};
        for (var i = 0, l = treeArray.length; i < l; i++) {
            // 以每条数据的id作为obj的key值,数据作为value值存入到一个临时对象里面
            tmpMap[treeArray[i]["id"]] = treeArray[i];
        }
        for (i = 0, l = treeArray.length; i < l; i++) {
            var key = tmpMap[treeArray[i]["fid"]];
            console.log("key", key);
            //循环每一条数据的 fid,假如这个临时对象有这个key值,就代表这个key对应的数据有children,需要Push进去
            //如果这一项数据属于哪个数据的子级
            if (key) {
                // 如果这个数据没有children
                if (!key["children"]) {
                    key["children"] = [];
                    key["children"].push(treeArray[i]);
                    // 如果这个数据有children
                } else {
                    key["children"].push(treeArray[i]);
                }
            } else {
                //如果没有这个Key值,就代表找不到属于哪个数据,那就代表没有父级,直接放在最外层
                res.push(treeArray[i]);
            }
        }
        return res;
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值