脑瓜子嗡嗡的 2020-09-03 13:00 采纳率: 0%
浏览 292
已采纳

大佬, 救命!!!树结构数据 拿到所有层级的nodeId 并生成一个新的数组 求大佬指导下 指条明路

急急急!!! 大佬救命

树结构数据(对象套childNode, childNode套childNode, 最后一级没有childNode) 初始四层, 但可以一直增加childNode 所以层数为N

数据格式
customJson: {
    content: "所有人",
    nodeId: "SID-f554f3db-74a2-a603-03d6-a0051f93bc60",
    type: "start",
    childNode: {
      content: "发起人自选",
      nodeId: "SID-12c519a1-e595-4ade-503e-9864f3e910ae",
      type: "fill",
      childNode: {
        content: "发起人自选",
        nodeId: "SID-a9fada60-4d12-8080-f7b2-4e54e0d1d4b2",
        type: "fill",
        childNode: {
          content: "发起人自选",
          nodeId: "SID-103d4a0a-df06-9745-13d8-eb758e35f6cd",
          type: "approved",
        }
      }
    }

希望得到的数组: [节点1nodeId , 节点2nodeId, 节点3nodeId ,  节点4nodeId ,...]

newArray: ["SID - f554f3db - 74a2 - a603 - 03d6 - a0051f93bc60",  "SID-12c519a1-e595-4ade-503e-9864f3e910ae", "SID-a9fada60-4d12-8080-f7b2-4e54e0d1d4b2"]

图片

图片说明

需求

需求是拿到所有层级的 nodeId 并生成一个新的数组 即希望得到的数组 newArray:[ 第一层的nodeId ,第二层的nodeId ,第三层的nodeId, 第四层的nodeId,... ] 求大佬指导下

  • 写回答

6条回答 默认 最新

  • 王二小丷 2020-09-03 13:58
    关注
    function map2Arr(map) {
        if (map) {
            let arr = [];
            arr.push(map.nodeId);
            let childNode = map.childNode;
            if (childNode) {
                // 递归调用
                arr = arr.concat(map2Arr(childNode));
            }
            return arr;
        }
        return [];
    }
    
    let arr = map2Arr(customJson);
    console.log(arr);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥100 求三轴之间相互配合画圆以及直线的算法
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站