通过与另一个数组匹配来覆盖数组元素值 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,如果 属性 idtemp 对象中,然后用新的内容替换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>');