AngularJS / javascript-将唯一值对象展平到SIMPLE列表中

时间:2018-09-05 10:28:13

标签: javascript arrays angularjs json flatten

我有一个动态生成的UNIQUE值的多层嵌套对象。我想将其展平(使用AngularJS或Vanilla JS),并为每个键/值创建一个简单的数组或对象。因此,如果对象看起来像这样:

[ 

{name : "parent",
 age: 21,
 children: [
     { name : "child",
     dob: [{
         day: "01",
         month: "01",
         year : "82"
     }],
     children: [
     { 
        name : "grandchild",
        dob: [{
            day: "01",
            month: "01",
            year : "02"
            }]
      }
    ]
   }
 ]
}

];

展平的对象应如下所示:

"name":"parent",
"age":21,
"children.name":"child",
"children.dob.day":"01",
"children.dob.month":"01",
"children.dob.year":"82",
"children.children.name":"grandchild",
"children.children.dob.day":"01",
"children.children.dob.month":"01",
"children.children.dob.year":"02"

我发现有2个函数可以展平一个对象,但是两个函数都在每个节点旁边插入索引。 (0.children.0.children.0.dob.0.year)这对我没有用,也没有必要,因为我的价值观是独一无二的。我需要上面的格式。您可以在此Codepen中看到我当前正在使用的功能: https://codepen.io/anon/pen/qMXEmB

有人可以帮助我从最终对象中删除那些讨厌的“零”吗?

1 个答案:

答案 0 :(得分:1)

野蛮,而不是

toReturn[i + '.' + x] = flatObject[x];

您可以这样删除0:

let index = i === "0" ? '' : i + '.';
toReturn[index + x] = flatObject[x];