你将如何实现一个映射函数,从一个对象键到另一个具有该特定键的属性的对象,同时保留对象结构
例如,给定这个输入对象:
{
person: {
first_name: "fn",
last_name: "ln",
address: {
city: "c",
street: "s",
},
movies: [
{
title: "movie1"
},
{
title: "movie2"
}
]
}
}
结果应该是:
{
name: "person",
children: [
{
name: "first_name"
},
{
name: "last_name"
},
{
name: "address",
children: [
{
name: "city"
},
{
name: "street"
}
]
},
{
name: "movies",
children: [
{
name: "title"
}
]
}
]
}
我尝试过一些递归对象遍历,但实现起来真的很丑陋。我觉得有更简单的方法来处理它
最佳答案
您可以使用递归来做到这一点。创建一个将条目作为输入的函数。条目是两个元素的数组,其中包含对象的键值对。 [键,值]
const obj = { person: { first_name: "fn", last_name: "ln", address: { city: "c", street: "s", }, movies: [ { title: "movie1" }, { title: "movie2" } ] } }
function getKeys(entry){
let obj = {
name:entry[0],
children:[]
}
const { children } = obj
let val = entry[1]
for(let k in val){
if(Array.isArray(val[k])){
children.push(getKeys([k,val[k][1]]));
}
else if(typeof val[k] === "object"){
children.push(getKeys([k,val[k]]))
}
else children.push({name:k})
}
if(!obj.children.length) delete obj.children;
return obj
}
console.log(getKeys(Object.entries(obj)[0]))
关于javascript - 将对象键和值映射到另一个对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56378866/