首页 > 解决方案 > Json 对象到网络图的数组

问题描述

我正在尝试构建一个网络图,其点数据为 [[from, to], [from,to]]。因此,我需要从 JSON 对象构建这种形式的数组。你能给我一个我可以做到的方法吗?我知道,这只是我们应用逻辑的方式,但我尝试了很多方法,但我无法做到。因此,我来​​这里是为了得到一个适用于任何深度对象的很好的逻辑。

我的示例对象就像

myObj = {
  Continents : 
  { Asia : {
      India : 1,
      China: 2 ,
      Japan : 3
    },
    Europe : {
      Sweden: 1,
      Norway : 2,
      Finland : 4,
      Denmark : 5
    },
    Africa : {
      Congo : 1,
      Kenya: 2,
      Zimbabwe : 3
    }
  }
}

物体的深度可以变化。现在我必须制作一个数组来形成如下节点。

myArray = [['Continents', 'Asia'],
           ['Continents', 'Europe'],
           ['Continents'], 'Africa'],
           ['Asia','India'],
           ['Asia','China'],
           ['Asia','Japan'],
           ['Europe', 'Sweden'],
           ['Europe', 'Norway'],
           ['Europe', 'Finland'],
           ['Europe', 'Denmark'],
           ['Africa', 'Congo'],
           ['Africa', 'Kenya'],
           ['Africa', 'Zimbabwe'],
]

标签: javascriptnode.jsangularhighcharts-ng

解决方案


您可以使用递归生成器:

  function* pairs(obj, parent) {
    for(const [key, value] of Object.entries(obj)) {
       if(parent) yield [parent, key];
       if(typeof value === "object")
          yield* pairs(value, key);
    }
 }

可用作:

  const result = [...pairs(obj)];

推荐阅读