通过与另一个数组匹配来覆盖数组元素值 javascript
Override an array element value by matching with another array javascript
array1 有 parent 和 children。 array2 在 array1 中几乎没有其他 children 个 parent。 array1 children 应替换为 array2
中的 children
数组 1:
{
"name": "USA",
"id": "country: USA",
"children": [
{
"name": "chicago",
"id": "country:USA>chicago"
},
{
"name": "arizona",
"id": "country:USA>arizona"
},
{
"name": "alabama",
"id": "country:USA>alabama"
}
]
},
{
"name": "xyz",
"id": "country:xyz",
"children": [
{
"name": "name1",
"id": "country:xyz>name1"
},
{
"name": "name2",
"id": "country:xyz>name2"
}
]
},
{
"name": "abc",
"id": "country:abc",
"children": [
{
"name": "name1",
"id": "country:abc>abc1"
},
{
"name": "name2",
"id": "country:abc>abc2"
}
]
}
数组 2:
[
{
"name": "name3",
"id": "country:xyz>name1"
},
{
"name": "georgia",
"id": "country:USA>georgia"
},
{
"name": "name4",
"id": "country:xyz>name4"
}
]
结果:
[
{
"name": "USA",
"id": "country:USA",
"children": [
{
"name": "georgia",
"id": "country:USA>georgia"
}
]
},
{
"name": "xyz",
"id": "country:xyz",
"children": [
{
"name": "name3",
"id": "country:xyz>name1"
},
{
"name": "name4",
"id": "country:xyz>name4"
}
]
},
{
"name": "abc",
"id": "country:abc",
"children": [
{
"name": "name1",
"id": "country:abc>abc1"
},
{
"name": "name2",
"id": "country:abc>abc2"
}
]
}
]
我试过但没有的代码 work.The 我的代码的问题是我取回了 array1 as-is 而我希望 array2 在 array1 中找到它的 parent。当它找到 parent 时,它应该用 array2 的数据替换 array1 children。
for (var j = 0; j < array2.length; j++) {
var parentId = array2[j].id.substr(0, array2[j].id.indexOf('>'));
for(var k=0; k < array1.length; k++){
if( parentId == array1[k].id){
if(array2[j].id.indexOf(array1[k].children.id) > -1){ //found a match
array1[k].children = [];
array1[k].children.push(array2[j]);
}
}
}
}
我建议用分组项目的键构建一个临时对象,然后遍历 array1
,如果 属性 id
在 temp
对象中,然后用新的内容替换children
的属性的内容。
var array1 = [{ "name": "USA", "id": "country:USA", "children": [{ "name": "chicago", "id": "country:USA>chicago" }, { "name": "arizona", "id": "country:USA>arizona" }, { "name": "alabama", "id": "country:USA>alabama" }] }, { "name": "xyz", "id": "country:xyz", "children": [{ "name": "name1", "id": "country:xyz>name1" }, { "name": "name2", "id": "country:xyz>name2" }] }, { "name": "abc", "id": "country:abc", "children": [{ "name": "name1", "id": "country:abc>abc1" }, { "name": "name2", "id": "country:abc>abc2" }] }],
array2 = [{ "name": "name3", "id": "country:xyz>name1" }, { "name": "georgia", "id": "country:USA>georgia" }, { "name": "name4", "id": "country:xyz>name4" }];
function f() {
var temp = {};
array2.forEach(function (a) {
var key = /(country:.*)>/i.exec(a.id)[1];
temp[key] = temp[key] || [];
temp[key].push(a);
});
array1.forEach(function (a) {
if (a.id in temp) {
a.children = temp[a.id];
}
});
}
f();
document.write('<pre>' + JSON.stringify(array1, 0, 4) + '</pre>');
array1 有 parent 和 children。 array2 在 array1 中几乎没有其他 children 个 parent。 array1 children 应替换为 array2
中的 children数组 1:
{
"name": "USA",
"id": "country: USA",
"children": [
{
"name": "chicago",
"id": "country:USA>chicago"
},
{
"name": "arizona",
"id": "country:USA>arizona"
},
{
"name": "alabama",
"id": "country:USA>alabama"
}
]
},
{
"name": "xyz",
"id": "country:xyz",
"children": [
{
"name": "name1",
"id": "country:xyz>name1"
},
{
"name": "name2",
"id": "country:xyz>name2"
}
]
},
{
"name": "abc",
"id": "country:abc",
"children": [
{
"name": "name1",
"id": "country:abc>abc1"
},
{
"name": "name2",
"id": "country:abc>abc2"
}
]
}
数组 2:
[
{
"name": "name3",
"id": "country:xyz>name1"
},
{
"name": "georgia",
"id": "country:USA>georgia"
},
{
"name": "name4",
"id": "country:xyz>name4"
}
]
结果:
[
{
"name": "USA",
"id": "country:USA",
"children": [
{
"name": "georgia",
"id": "country:USA>georgia"
}
]
},
{
"name": "xyz",
"id": "country:xyz",
"children": [
{
"name": "name3",
"id": "country:xyz>name1"
},
{
"name": "name4",
"id": "country:xyz>name4"
}
]
},
{
"name": "abc",
"id": "country:abc",
"children": [
{
"name": "name1",
"id": "country:abc>abc1"
},
{
"name": "name2",
"id": "country:abc>abc2"
}
]
}
]
我试过但没有的代码 work.The 我的代码的问题是我取回了 array1 as-is 而我希望 array2 在 array1 中找到它的 parent。当它找到 parent 时,它应该用 array2 的数据替换 array1 children。
for (var j = 0; j < array2.length; j++) {
var parentId = array2[j].id.substr(0, array2[j].id.indexOf('>'));
for(var k=0; k < array1.length; k++){
if( parentId == array1[k].id){
if(array2[j].id.indexOf(array1[k].children.id) > -1){ //found a match
array1[k].children = [];
array1[k].children.push(array2[j]);
}
}
}
}
我建议用分组项目的键构建一个临时对象,然后遍历 array1
,如果 属性 id
在 temp
对象中,然后用新的内容替换children
的属性的内容。
var array1 = [{ "name": "USA", "id": "country:USA", "children": [{ "name": "chicago", "id": "country:USA>chicago" }, { "name": "arizona", "id": "country:USA>arizona" }, { "name": "alabama", "id": "country:USA>alabama" }] }, { "name": "xyz", "id": "country:xyz", "children": [{ "name": "name1", "id": "country:xyz>name1" }, { "name": "name2", "id": "country:xyz>name2" }] }, { "name": "abc", "id": "country:abc", "children": [{ "name": "name1", "id": "country:abc>abc1" }, { "name": "name2", "id": "country:abc>abc2" }] }],
array2 = [{ "name": "name3", "id": "country:xyz>name1" }, { "name": "georgia", "id": "country:USA>georgia" }, { "name": "name4", "id": "country:xyz>name4" }];
function f() {
var temp = {};
array2.forEach(function (a) {
var key = /(country:.*)>/i.exec(a.id)[1];
temp[key] = temp[key] || [];
temp[key].push(a);
});
array1.forEach(function (a) {
if (a.id in temp) {
a.children = temp[a.id];
}
});
}
f();
document.write('<pre>' + JSON.stringify(array1, 0, 4) + '</pre>');