首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何合并两个对象数组,只保留新对象并获取旧对象的属性?

如何合并两个对象数组,只保留新对象并获取旧对象的属性?
EN

Stack Overflow用户
提问于 2022-01-12 04:18:16
回答 2查看 42关注 0票数 -1

我知道有很多类似这个题目的题目,但我找不到解决我问题的题目。

关键是我避免了对数据库的不必要查询。因此,当查询完成时,只消耗所需的内容。我获取数据并将其与LocalStorage合并以节省使用。

我创建这个示例是为了更容易地阅读和帮助未来的用户:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
let usersDB = [
  { id: 1, name: 'John', age: 34 },
  { id: 2, name: 'Rose', age: 27 },
  { id: 3, name: 'Daniel', age: 40 },
]
const usersLS = [
  { id: 1, name: 'John', cars: ['BMW', 'Ferrari'] },
  { id: 2, name: 'Rose', cars: ['Tesla', 'Camaro'] },
  { id: 4, name: 'Ambrose', cars: ['Fiat'] },
]

/** Expected Result:
 * [
 *   {id: 1, name: 'John', cars: ['BMW', 'Ferrari']},
 *   {id: 2, name: 'Rose', cars: ['Tesla', 'Camaro']},
 *   {id: 3, name: 'Daniel'},
 * ]
 */

在上面的示例中,userDBuserLS分别表示数据库用户和LocalStorage用户。

当然,userDB是“更新”最多的,但是userLS有一个属性"cars“,它与数据库中的用户不在同一表中。因此,我需要使用userLS作为基础更新userDB,但不会丢失"cars“属性。

我知道我可以做一个for...loop来迭代用户,在这个for...loop中,另一个for...loop来检查id是否相同,然后用对象生成一个新的数组。但是,我认为必须有更好的办法来解决这个问题。

编辑:我尝试过的

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
let newArr = [];

for (let userDB of usersDB) {
  for (let userLS of usersLS) {
    if (userDB.id === userLS.id) {
      userDB.cars = userLS.cars
      newArr.push(userDB);
    }
  }
}
usersDB = Object.assign([...usersDB], ...newArr)

上面的代码就是我用来解决这个问题的方法。你能想出更直接的解决办法吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-01-12 04:54:04

您可以在Array.map()数组上使用usersDB,然后将属性与为任何给定用户找到的任何userLS合并。

我们使用扩展语法合并数组中的每个项:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
const usersDB = [
  { id: 1, name: 'John', age: 34 },
  { id: 2, name: 'Rose', age: 27 },
  { id: 3, name: 'Daniel', age: 40 },
]

const usersLS = [
  { id: 1, name: 'John', cars: ['BMW', 'Ferrari'] },
  { id: 2, name: 'Rose', cars: ['Tesla', 'Camaro'] },
  { id: 4, name: 'Ambrose', cars: ['Fiat'] },
]

const result = usersDB.map(( { age, ...userDB}, idx) => { 
    let userLS = usersLS.find(u => u.id === userDB.id);
    return { ...userLS, ...userDB};
}, {})

console.log('Result:', result)
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
.as-console-wrapper { max-height: 100% !important; top: 0; }

票数 1
EN

Stack Overflow用户

发布于 2022-01-12 04:55:52

Array.map会帮上忙

逻辑

  • usersDB数组用Array.map循环
  • usersLS数组中查找比较id的匹配节点
  • 如果找到匹配节点,则将来自该对象的cars属性从map函数分配给返回节点。

工作部件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
let usersDB = [
  { id: 1, name: 'John', age: 34 },
  { id: 2, name: 'Rose', age: 27 },
  { id: 3, name: 'Daniel', age: 40 },
]
const usersLS = [
  { id: 1, name: 'John', cars: ['BMW', 'Ferrari'] },
  { id: 2, name: 'Rose', cars: ['Tesla', 'Camaro'] },
  { id: 4, name: 'Ambrose', cars: ['Fiat'] },
];
const userConsolidated = usersDB.map((user) => {
  const usersLSnode = usersLS.find((item) => item.id === user.id);
  const { id, name } = user;
  const returnNode = { id, name };
  if (usersLSnode) returnNode.cars = usersLSnode.cars;
  return returnNode
});

console.log(userConsolidated);

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70681441

复制
相关文章
回顾R和微软过去的一年
托马斯·斯莫尔的ML / DL博客最近回顾了数据科学,机器学习和深度学习显著的进步-其中许多涉及R和/或微软。以下是他们的亮点: R Project R和Python保持其作为开放数据科学主要工具的领导地位。Python与R的争论仍在继续,一个新的共识是数据科学家应该考虑学习两者。R有一个更强大的统计和机器学习技术库,在使用小数据时更加灵活。Python更适合开发应用程序,而Python开源许可证对商业应用程序开发的限制较少。 R用户社区在2016年继续扩大。在2016年O'Reilly数据科学薪资调查
小莹莹
2018/04/23
9500
回顾R和微软过去的一年
云计算费用管理的最佳实践
随着IT日益成为使用和服务两方面的基础,基于带宽、交易、资源范围、访问事件、用户数量、服务和账户等的各种定价模式已经出现。
静一
2018/07/31
3.2K0
云计算费用管理的最佳实践
NER的过去、现在和未来综述-过去
命名实体识别(NER, Named Entity Recognition),是指识别文本中具有特定意义的实体,主要包括人名、地名、机构名、专有名词等。
百川AI
2021/10/25
2K0
NER的过去、现在和未来综述-过去
r语言求平均值_r语言计算中位数
R中的统计分析通过使用许多内置函数来执行的,这些函数大部分是R基础包的一部分,并且它们将R向量与参数一起作为输入,并在执行计算后给出结果。
全栈程序员站长
2022/09/29
2.2K0
r语言求平均值_r语言计算中位数
「R」如何计算几何平均数
刚遇到一个有意思的问题,如何用R计算几何平均数。如果数字少,简单,计算很容易,直观上,先用prod函数连乘,然后开方即可。
王诗翔呀
2020/07/03
2.3K0
CI/CD 和 DevOps 的过去和未来
本文由 DevOps时代高翻院整理发布 十年前,DevOps 的理念在 Andrew Shafer 和 Patrick Debois 两位先驱的脑海中酝酿。一年之后,他们将其正式命名为“DevOps”。光阴荏苒,今年是 DevOps 诞生的十周年,本文将回顾 DevOps 的历程,并且展望 DevOps 的未来。 本文内容会尽量和某些 IT 厂商、商业产品或开源产品等等无关。我们会专注讨论 DevOps、CI/CD 的历史,探究这些理念的发展形态,并尝试预测这一领域美好未来。 脱胎于敏捷运动的 “De
DevOps时代
2018/04/17
1.7K0
CI/CD 和 DevOps 的过去和未来
使用SQL计算宝宝每次吃奶的时间间隔
需求:媳妇儿最近担心宝宝的吃奶时间不够规律,网上说是正常平均3小时喂奶一次,让我记录下每次的吃奶时间,分析下实际是否偏差很大,好在下次去医院复查时反馈给医生。 此外,还要注意有时候哭闹要吃奶,而实际只吃了两口便不吃了。这种情况要特殊标记下,如果不算这种情况的话,分析看是否正常。 环境:Oracle 11.2.0.4
Alfred Zhao
2019/12/17
1.3K0
激荡十年:云计算的过去、现在和未来(二)
昨天给大家介绍了《激荡十年:云计算的过去、现在和未来(一)》,今天介绍云计算的未来。
CloudBest
2019/08/02
9410
激荡十年:云计算的过去、现在和未来(二)
弯曲的旅行
宇宙隐藏着与我们想象中完全不同的维度吗?我们将怎样证实这些维度的存在?四维世界甚至五维世界的存在,是否会颠覆传统的物理学定律?
用户3157710
2018/10/10
3520
弯曲的旅行
FPGA的过去、现状和未来
本文是多为作者的讨论总结。这些总结包含了以下组织的经验:Zilog, Altera, Xilinx, Achronix, Intel, IBM,斯坦福,麻省理工,伯克利,威斯康星大学,Technion, Fairchild,贝尔实验室,Bigstream,谷歌,DEC, SUN,诺基亚,SRI,日立,Silicom,Maxeler技术,VMware,施乐PARC,思科等。但这些组织并不对内容负责,只是在某些方面给了作者一些启发,使得本文对FPGA领域的描述显得丰富多彩。
用户9624935
2022/04/02
7420
FPGA的过去、现状和未来
NFT 的过去、现在和未来
随着企业和开发人员过渡到 Web 3.0 的世界,您一定已经看到NFT或不可替代令牌这个词被广泛使用,尤其是在社交媒体上。虽然只截屏以“拥有”NFT 很诱人,但它们的用途远远超出了个人资料照片或 PFP。
飞机号dapp119
2022/12/12
4600
NFT 的过去、现在和未来
Filecoin的过去、现在和未来
Filecoin网络是在互联网架构变革的中期推出的。在这场变革中,脆弱的中心化服务(依赖于受信任方),正在被基于可验证计算的弹性去中心化解决方案所取代。互联网服务正在从低效的中心化单体服务转移到网络的边缘,这其中的推手是正在崛起的p2p市场。
用户9624935
2022/04/02
6930
Filecoin的过去、现在和未来
NFT 的过去、现在和未来
在开始学习一门新的概念之前,了解它的历史是很有必要的! 过去:第一个NFT是什么时候诞生的? 就像创新技术的情况一样,NFTs并不是突然冒出来,一夜之间成为家喻户晓的名字。这自然就引出了一个问题:第一
前端修罗场
2022/07/29
4240
NFT 的过去、现在和未来
Fragment 的过去、现在和将来
Fragment 是 Android 中历史十分悠久的一个组件,它在 API 11 被加入,时至今日已成为 Android 开发中最常用的组件之一。Fragment 有了哪些新特性、修复了哪些问题,都是开发者们十分关心的话题。下面我们就来重新说一说 Fragment —— 不仅仅是说现在的 Fragment,还会回顾它的发展,并让您一瞥它未来的样子。
Android 开发者
2020/06/24
9290
Fragment 的过去、现在和将来
商标注册费用怎么计算的
商标注册官费是300元,(限定本类10个商品。10个以上商品,每超过1个商品,每个商品加收30元)
李昂君
2021/12/24
1.1K0
商标注册费用怎么计算的
计算每个请求的平均响应时间
目的 找出是哪些请求长期影响了系统性能 方法 web服务器的日志会记录每个请求的响应时间,分析访问日志,对相同请求的响应时间进行累加,响应时间的和 除以 这个请求的访问次数,就得到此请求的平均访问时间
dys
2018/04/03
3.1K0
计算每个请求的平均响应时间
PowerBI DAX 计算客户的平均交易年龄
本文来研究客户的交易年龄。与自然年龄不同,交易年龄指的是客户在发生交易时的年龄,这在多年分析中的差异就会非常显著。
BI佐罗
2021/03/25
1.8K0
PowerBI DAX 计算客户的平均交易年龄
GDAL计算平均值的图(tif)
假如你手上有100000张v26h8的ndvi,modis数据,这时候你想知道他们平均的结果。。。改使用如下代码。。。。废话不多说:
一个有趣的灵魂W
2020/09/15
2K0
GDAL计算平均值的图(tif)
Linux系统平均负载是如何计算的?[通俗易懂]
关于负载的计算,它的结果是包含有小数的一个浮点数,内核中是不能使用float变量的,那么这里就采用了一个整型变量的低11位来表示小数部分。那么对于数值1来说,它就是FIXED_1,也就是需要对1进行左移11bit。实际上此时这个整型变量保存的值是1024。
全栈程序员站长
2022/10/02
2.3K0
计算平均分
/* 功能:计算平均分 日期:2013-04-01 */ #include<stdio.h> #include<stdlib.h> #include<math.h>
WindCoder
2018/09/20
7280

相似问题

根据月数计算总费用。

11

基于变化的订阅费计算总费用

16

如何创建计算总费用的sql过程

35

总费用

24

Python -总费用

39
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文