如何合并两个JSON对象数组 – 删除重复项并保留Javascript / jQuery中的顺序?

jsfiddle链接:http://jsfiddle.net/vN6fn/1/

假设我有这两个对象:

var obj1 = { data: [ 
                      {id:1, comment:"comment1"},
                      {id:2, comment:"comment2"},
                      {id:3, comment:"comment3"}
                   ] }

var obj2 = { data: [ 
                      {id:2, comment:"comment2"},
                      {id:3, comment:"comment3"},
                      {id:4, comment:"comment4"}
                   ] }

最终对象应如下所示:

var final = { data: [ 
                      {id:1, comment:"comment1"},
                      {id:2, comment:"comment2"},
                      {id:3, comment:"comment3"},
                      {id:4, comment:"comment4"}
                   ] }

这里有一些要考虑的事情:

> obj1和obj2可能有也可能没有重复

$.extend()替换对象,$.merge()不会删除重复项(我知道我可以为循环执行,但我正在寻找更好的方法来执行此操作).

您可以使用$.merge然后浏览并删除重复项,然后对其进行排序.

$.merge(obj1.data, obj2.data);

var existingIDs = [];
obj1.data = $.grep(obj1.data, function(v) {
    if ($.inArray(v.id, existingIDs) !== -1) {
        return false;
    }
    else {
        existingIDs.push(v.id);
        return true;
    }
});

obj1.data.sort(function(a, b) {
    var akey = a.id, bkey = b.id;
    if(akey > bkey) return 1;
    if(akey < bkey) return -1;
    return 0;
});
翻译自:https://stackoverflow.com/questions/9134649/how-to-merge-two-arrays-of-json-objects-removing-duplicates-and-preserving-ord

转载注明原文:如何合并两个JSON对象数组 – 删除重复项并保留Javascript / jQuery中的顺序?