通过 javascript 键比较两个对象数组
compare two object arrays by javascript keys
我正在使用 javascript 我有两个安排,示例如下所示:
const arr1 = [
{ url: 1, 'title': 'A', 'title2': 'A2' },
{ url: 2, 'title': 'B', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'E', 'title2': 'E2' },
]
const arr2 = [
{ url: 1, 'title': 'A', 'title2': 'J2' },
{ url: 2, 'title': 'J', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'K', 'title2': 'E2' },
]
我想从第二个数组中获取那些不同于 title
或 title2
的对象
我尝试了以下方法,但它对我不起作用,我在哪里迷路了?
const res = arr2.filter((page1) => !arr1.some(page2 => page1.title === page2.title || page2.title2 == page1.title2 ))
示例的预期结果是这样的:
[{ url: 1, 'title': 'A', 'title2': 'J2' },{"url":2,"title":"J","title2":"B2"},{"url":5,"title":"K","title2":"E2"}]
如果我理解您的目标,那就是首先匹配 URL,然后找出标题中是否存在差异。如果这是正确的,这将带你到那里。
const res = arr2.filter(page1 => {
// find URL match
let page2 = arr1.find(f => f.url === page1.url)
return !page2 || page2.title != page1.title || page2.title2 != page1.title2;
})
const arr1 = [
{ url: 1, 'title': 'A', 'title2': 'A2' },
{ url: 2, 'title': 'B', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'E', 'title2': 'E2' },
]
const arr2 = [
{ url: 1, 'title': 'A', 'title2': 'J2' },
{ url: 2, 'title': 'J', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'K', 'title2': 'E2' },
]
const res = arr2.filter(page1 => {
// find URL match
let page2 = arr1.find(f => f.url === page1.url)
return !page2 || page2.title != page1.title || page2.title2 != page1.title2;
})
console.log(res)
您可以通过使用 url
作为键从对象中收集来自 array1
的所有对象,并通过检查 title
和 title2
.[=16 过滤第二个数组=]
const
array1 = [{ url: 1, 'title': 'A', 'title2': 'A2' }, { url: 2, 'title': 'B', 'title2': 'B2' }, { url: 3, 'title': 'C', 'title2': 'C2' }, { url: 4, 'title': 'D', 'title2': 'D2' }, { url: 5, 'title': 'E', 'title2': 'E2' }],
array2 = [{ url: 1, 'title': 'A', 'title2': 'J2' }, { url: 2, 'title': 'J', 'title2': 'B2' }, { url: 3, 'title': 'C', 'title2': 'C2' }, { url: 4, 'title': 'D', 'title2': 'D2' }, { url: 5, 'title': 'K', 'title2': 'E2' }],
keys = ['title', 'title2'],
urls = Object.fromEntries(array1.map(o => [o.url, o])),
result = array2.filter(o => keys.some(k => o[k] !== urls[o.url][k]));
console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }
最简单的方法是将第一个映射到查找并循环第二个。
const arr1 = [
{ url: 1, 'title': 'A', 'title2': 'A2' },
{ url: 2, 'title': 'B', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'E', 'title2': 'E2' },
];
const arr2 = [
{ url: 1, 'title': 'A', 'title2': 'J2' },
{ url: 2, 'title': 'J', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'K', 'title2': 'E2' },
];
const arr1MapByUrl = arr1.reduce((acc, data) => {
acc[data.url] = data;
return acc;
}, {});
const results = arr2.filter(data => {
const org = arr1MapByUrl[data.url];
return !org || data.title !== org.title || data.title2 !== org.title2;
});
console.log(results);
如果您不想对密钥进行硬编码以进行检查,您可以使用 some() 遍历它们并进行比较。
const arr1 = [
{ url: 1, 'title': 'A', 'title2': 'A2' },
{ url: 2, 'title': 'B', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'E', 'title2': 'E2' },
];
const arr2 = [
{ url: 1, 'title': 'A', 'title2': 'J2' },
{ url: 2, 'title': 'J', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'K', 'title2': 'E2' },
];
const arr1MapByUrl = arr1.reduce((acc, data) => {
acc[data.url] = data;
return acc;
}, {});
const results = arr2.filter(data => {
const org = arr1MapByUrl[data.url];
return !org || Object.entries(data).some(([key, value]) => org[key] !== value);
});
console.log(results);
构建一个 object 来跟踪基于 arr1
的标题并使用相同的 object 来过滤 arr2
const arr1=[{url:1,title:"A",title2:"A2"},{url:2,title:"B",title2:"B2"},{url:3,title:"C",title2:"C2"},{url:4,title:"D",title2:"D2"},{url:5,title:"E",title2:"E2"}];
const arr2=[{url:1,title:"A",title2:"J2"},{url:2,title:"J",title2:"B2"},{url:3,title:"C",title2:"C2"},{url:4,title:"D",title2:"D2"},{url:5,title:"K",title2:"E2"}];
const track = {};
arr1.forEach(({ url, title, title2 }) =>
Object.assign(track, { [url]: { [title]: title2 } })
);
const results = arr2.filter(
({ url, title, title2 }) => track?.[url]?.[title] !== title2
);
console.log(results)
我正在使用 javascript 我有两个安排,示例如下所示:
const arr1 = [
{ url: 1, 'title': 'A', 'title2': 'A2' },
{ url: 2, 'title': 'B', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'E', 'title2': 'E2' },
]
const arr2 = [
{ url: 1, 'title': 'A', 'title2': 'J2' },
{ url: 2, 'title': 'J', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'K', 'title2': 'E2' },
]
我想从第二个数组中获取那些不同于 title
或 title2
我尝试了以下方法,但它对我不起作用,我在哪里迷路了?
const res = arr2.filter((page1) => !arr1.some(page2 => page1.title === page2.title || page2.title2 == page1.title2 ))
示例的预期结果是这样的:
[{ url: 1, 'title': 'A', 'title2': 'J2' },{"url":2,"title":"J","title2":"B2"},{"url":5,"title":"K","title2":"E2"}]
如果我理解您的目标,那就是首先匹配 URL,然后找出标题中是否存在差异。如果这是正确的,这将带你到那里。
const res = arr2.filter(page1 => {
// find URL match
let page2 = arr1.find(f => f.url === page1.url)
return !page2 || page2.title != page1.title || page2.title2 != page1.title2;
})
const arr1 = [
{ url: 1, 'title': 'A', 'title2': 'A2' },
{ url: 2, 'title': 'B', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'E', 'title2': 'E2' },
]
const arr2 = [
{ url: 1, 'title': 'A', 'title2': 'J2' },
{ url: 2, 'title': 'J', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'K', 'title2': 'E2' },
]
const res = arr2.filter(page1 => {
// find URL match
let page2 = arr1.find(f => f.url === page1.url)
return !page2 || page2.title != page1.title || page2.title2 != page1.title2;
})
console.log(res)
您可以通过使用 url
作为键从对象中收集来自 array1
的所有对象,并通过检查 title
和 title2
.[=16 过滤第二个数组=]
const
array1 = [{ url: 1, 'title': 'A', 'title2': 'A2' }, { url: 2, 'title': 'B', 'title2': 'B2' }, { url: 3, 'title': 'C', 'title2': 'C2' }, { url: 4, 'title': 'D', 'title2': 'D2' }, { url: 5, 'title': 'E', 'title2': 'E2' }],
array2 = [{ url: 1, 'title': 'A', 'title2': 'J2' }, { url: 2, 'title': 'J', 'title2': 'B2' }, { url: 3, 'title': 'C', 'title2': 'C2' }, { url: 4, 'title': 'D', 'title2': 'D2' }, { url: 5, 'title': 'K', 'title2': 'E2' }],
keys = ['title', 'title2'],
urls = Object.fromEntries(array1.map(o => [o.url, o])),
result = array2.filter(o => keys.some(k => o[k] !== urls[o.url][k]));
console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }
最简单的方法是将第一个映射到查找并循环第二个。
const arr1 = [
{ url: 1, 'title': 'A', 'title2': 'A2' },
{ url: 2, 'title': 'B', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'E', 'title2': 'E2' },
];
const arr2 = [
{ url: 1, 'title': 'A', 'title2': 'J2' },
{ url: 2, 'title': 'J', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'K', 'title2': 'E2' },
];
const arr1MapByUrl = arr1.reduce((acc, data) => {
acc[data.url] = data;
return acc;
}, {});
const results = arr2.filter(data => {
const org = arr1MapByUrl[data.url];
return !org || data.title !== org.title || data.title2 !== org.title2;
});
console.log(results);
如果您不想对密钥进行硬编码以进行检查,您可以使用 some() 遍历它们并进行比较。
const arr1 = [
{ url: 1, 'title': 'A', 'title2': 'A2' },
{ url: 2, 'title': 'B', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'E', 'title2': 'E2' },
];
const arr2 = [
{ url: 1, 'title': 'A', 'title2': 'J2' },
{ url: 2, 'title': 'J', 'title2': 'B2' },
{ url: 3, 'title': 'C', 'title2': 'C2' },
{ url: 4, 'title': 'D', 'title2': 'D2' },
{ url: 5, 'title': 'K', 'title2': 'E2' },
];
const arr1MapByUrl = arr1.reduce((acc, data) => {
acc[data.url] = data;
return acc;
}, {});
const results = arr2.filter(data => {
const org = arr1MapByUrl[data.url];
return !org || Object.entries(data).some(([key, value]) => org[key] !== value);
});
console.log(results);
构建一个 object 来跟踪基于 arr1
的标题并使用相同的 object 来过滤 arr2
const arr1=[{url:1,title:"A",title2:"A2"},{url:2,title:"B",title2:"B2"},{url:3,title:"C",title2:"C2"},{url:4,title:"D",title2:"D2"},{url:5,title:"E",title2:"E2"}];
const arr2=[{url:1,title:"A",title2:"J2"},{url:2,title:"J",title2:"B2"},{url:3,title:"C",title2:"C2"},{url:4,title:"D",title2:"D2"},{url:5,title:"K",title2:"E2"}];
const track = {};
arr1.forEach(({ url, title, title2 }) =>
Object.assign(track, { [url]: { [title]: title2 } })
);
const results = arr2.filter(
({ url, title, title2 }) => track?.[url]?.[title] !== title2
);
console.log(results)