1

有对象:

Nested1: {
    "nested21": {
        "nested31": {
            value: "im sooo nested"
        } ,
        "nested32": {
            value: "im sooo nested"
        }
    },
    "nested22": {
        "nested31": {
            value: "im sooo nested"
        } ,
        "nested32": {
            value: "im sooo nested"
        }
    }
}

在可能存在未定义数量的嵌套对象的情况下,我想得到类似的东西:

Nested1.nested21.nested31 - 我太嵌套了
Nested1.nested21.nested32 - 我太嵌套了

等等

我正在考虑一个递归函数,但是如何将链式键保存在内存中?

4

1 回答 1

0

知道了

var obj, traverse;

obj = {
  a: {
    b: 1,
    c: 2
  },
  d: {
    e: 3,
    f: 4
  }
};

traverse = function(node, path) {
  var pairs;
  if (!(pairs = _(node).pairs()).length) {
    return [
      {
        keys: path,
        value: node
      }
    ];
  } else {
    return [].concat.apply([], _(pairs).map(function(kv) {
      return traverse(kv[1], path.concat(kv[0]));
    }));
  }
};

console.log(traverse(obj, []));
于 2013-06-21T09:06:44.030 回答