我有一个数据数组(实际上是带有标题的MySQL解析后的CSV转储)
['adam', 'smith', 'honda', 'civic']
我有一个对象,它定义了该数据数组应该如何看作对象。
{
first_name : 0,
last_name: 1,
car : {
make: 2,
model: 3
}
}
此对象可以具有任何深度的嵌套值。它也是动态生成的。
我的问题是:如何将数组中的值转换为对象?
(我试图在对象上进行递归函数循环并抓取当前的数组,但继续运行到墙壁。如果我让它工作,我会发布它,但我怀疑有一种更简单的方法来完成它。 )
答案 0 :(得分:3)
这是一种方法。它适用于你提出的案例。
小提琴:http://jsfiddle.net/wy0doL5d/8/
var arr = ['adam', 'smith', 'honda', 'civic']
var obj = {
first_name : 0,
last_name: 1,
car : {
make: 2,
model: 3
}
}
function mapObj(o, a)
{
Object.keys(o).forEach(function(key){
var objType = typeof(o[key]);
if(objType === "object")
{
mapObj(o[key], a);
}
else
{
o[key] = a[o[key]];
}
});
}
mapObj(obj, arr);
答案 1 :(得分:1)
您可以尝试这样的事情:
var myarray = ['adam', 'smith', 'honda', 'civic'];
var myobject = {
first_name: 0,
last_name: 1,
car: {
make: 2,
model: 3
}
};
function objectLoop(obj) {
for (var key in obj) {
if (obj.hasOwnProperty(key)) {
if (typeof obj[key] == 'number') {
obj[key] = myarray[obj[key]];
} else {
objectLoop(obj[key]);
}
}
}
return obj;
}
console.log(objectLoop(myobject));
这是一个快速写。可能有一些我没有考虑的用例,但它确实适用于上面的数据。它可以扩展。
答案 2 :(得分:1)
可能的解决方案之一!
var arr =['adam', 'smith', 'honda', 'civic'];
var obj = {
first_name : 0,
last_name: 1,
car : {
make: 2,
model: 3
}
}
function isNumber(n) {
return !isNaN(parseFloat(n)) && isFinite(n);
}
function extract( argObj , argArr){
var o = {};
Object.keys( argObj ).forEach(function( k ){
var curDef = argObj[k];
if(isNumber( curDef ) ){
o[k] = argArr[ curDef ];
return;
}
o[k] = extract( curDef , argArr);
})
return o;
}
var newO = extract(obj, arr);
console.dir( newO );
document.body.innerHTML+= '<pre>' + JSON.stringify(newO , null , ' ') + '</pre>';
&#13;