响应以递归方式遍历嵌套对象



我正在尝试递归迭代嵌套对象以获取键和值。

我的数据结构是:

  {         
    "id": 8743077530231325861,
    "name": "Name of XYZ",
    "key X": 0,
    "key Y": {
      "details": {
        "value": {
          "up": 5,
          "down": 3
        },
        "path": "xyz"
      },
      "key Z": {
        "value": 1,
        "path": "abc"
      }
    },
    "createdTimestamp": 1554446703000
  }

我的函数是:

  recursion = (item, keyString) => {
    if(isObject(item)){
      Object.keys(item).map((key) => {
        return this.recursion(item[key], keyString+`.${key}`)
      })
    }else{
      return {item, keyString}
    }
  }

我这样称呼它:

Object.keys(data).map(key =>{
   console.log(this.recursion(data[key], key))
})

我的问题是作为对象的键总是未定义的。我知道这是因为他们需要在其他时间迭代,并且输出比函数更快。当我打印出递归函数末尾的值而不是返回它们时,它们不是未定义的。

最后,我希望每个键都有最深的值和"路径"。例如

8743077530231325861,"id"
Name of XYZ,"name"
0, "keyX"
5, "keyY.details.value.up"
...

我已经尝试使用等待/异步,但我无法获取所有值

如果有人对我有提示会很好

您需要返回映射的结果。

const
    isObject = v => v && typeof v === 'object',
    recursion = (item, path = '') => isObject(item)
        ? Object
            .keys(item)
            .flatMap(k => recursion(item[k], path + (path && '.') + k))
        : { item, path };
var data = { id: 8743077530231326000, name: "Name of XYZ", "key X": 0, "key Y": { details: { value: { up: 5, down: 3 }, path: "xyz" }, "key Z": { value: 1, path: "abc" } }, createdTimestamp: 1554446703000 },
    result = recursion(data);
console.log(result);

最新更新