我有两个对象数组:
A = [
{ id1: "1", id2: "a", p1: "3", p2: "4" },
{ id1: "1", id2: "b", p1: "5", p2: "6" },
{ id1: "2", id2: "a", p1: "7", p2: "8" },
{ id1: "2", id2: "b", p1: "9", p2: "10" }
];
B = [
{ id1: "1", id2: "a", p3: "13", p4: "14" },
{ id1: "1", id2: "b", p3: "15", p4: "16" },
{ id1: "2", id2: "a", p3: "17", p4: "18" },
{ id1: "2", id2: "b", p3: "19", p4: "20" }
];
我需要一个函数,该函数基于两个属性
id1
和id2
在两个对象之间进行内部联接,并合并其他属性(除了id1
和id2
以外,属性名称永远不相等)换句话说,我需要:
C = [
{ id1: "1", id2: "a", p1: "3", p2: "4", p3: "13", p4: "14" },
{ id1: "1", id2: "b", p1: "5", p2: "6", p3: "15", p4: "16" },
{ id1: "2", id2: "a", p1: "7", p2: "8", p3: "17", p4: "18" },
{ id1: "2", id2: "b", p1: "9", p2: "10", p3: "19", p4: "20" }
];
在这里,我可以找到一种使用一个键进行联接的方法。
我需要扩展多个键的情况。
http://learnjsdata.com/combine_data.html
最佳答案
两者提供的答案均未提供预期的结果(内部联接应该只包含两个数据集中的匹配项)。
我有一些扩展的输入数组,以演示提供的答案和我的答案的输出差异:
const A = [
{id1:"1", id2:"a", p1:"3", p2:"4"},
{id1:"1", id2:"b", p1:"5", p2:"6"},
{id1:"2", id2:"a", p1:"7", p2:"8"},
{id1:"2", id2:"b", p1:"9", p2:"10"},
{id1:"3", id2:"c", p1:"1", p2:"3"}
];
const B = [
{id1:"1", id2:"a", p3:"13", p4:"14"},
{id1:"1", id2:"b", p3:"15", p4:"16"},
{id1:"2", id2:"a", p3:"17", p4:"18"},
{id1:"2", id2:"b", p3:"19", p4:"20"},
{id1:"4", id2:"k", p3:"11", p4:"13"}
];
const innerJoined = A.reduce((result, itemA) => {
const itemB = B.find(itemB => itemB.id1 == itemA.id1 && itemB.id2 == itemA.id2);
if(itemB) result.push({...itemA, ...itemB});
return result;
}, []);
console.log(innerJoined);
关于javascript - 在Javascript中的多个键上连接对象数组,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/55832412/