// 示例数组对象a
const a = [
{id: 1, name: 'obj1'},
{id: 2, name: 'obj2'},
{id: 3, name: 'obj3'}
];
// 示例数组对象b
const b = [
{id: 2, name: 'obj2 updated'},
{id: 4, name: 'new obj'}
];
const bIds = new Set(b.map(item => item.id));
const result = a.filter(item => bIds.has(item.id)).concat(b.filter(item =>!a.some(aItem => aItem.id === item.id)));
console.log(result);
// 打印[{id: 2, name: 'obj2'}, {id: 4, name: 'new obj'}]
代码解释如下:
- 首先,使用 Set 数据结构创建一个集合 bIds ,它包含了数组对象 b 中所有元素的 id 值。这样后续通过 has 方法判断某个 id 是否存在时,时间复杂度为 O(1) ,比遍历数组查找更高效。2. 然后通过 filter 方法对数组对象 a 进行过滤,只保留 id 在 bIds 集合中的元素,也就是去掉了 a 中 b 里没有的元素,这一步实现了删除操作。3. 接着,再使用 filter 方法对数组对象 b 进行筛选,找出 b 中那些 id 不在 a 中的元素,也就是 b 有而 a 没有的元素,然后通过 concat 方法将这些新增元素连接到前面过滤后的结果上,实现了添加操作。 最终 result 数组就是按照要求处理后的结果,符合基于 b 对 a 进行相应增删并保留 a 原始顺序的逻辑。你可以根据实际情况调整代码中用于判断唯一性的属性等内容。

1775

被折叠的 条评论
为什么被折叠?



