数组合并和对象合并方法

文章讲述了在项目开发中,如何处理下拉框选中参数变化时,同步更新相关节点属性的问题,使用了Object.assign()进行对象合并,并讨论了数组合并的不同方法如扩展运算符和concat(),以及在对象合并时属性覆盖的特性。
摘要由CSDN通过智能技术生成

写作背景:项目中有一个下拉框,选中时会带出一个参数数组,渲染成列表,某个节点中也包含该选项的一些参数数据,当下拉框中的参数在后台发生了变化时,比如增加一个参数或者减少一个参数,那对应这个节点的属性也要保持和当前下拉框所属参数一致,只是值为空。
具体数据如下:

const selectObjParams = {
  "agv": "",
  "chargeStationId": "",
  "maxChargeCurrent": "",
  "maxChargeVoltage": "",
  "chargeLevel": ""
};

const nodeParams = {
  "agv": "[#context.node.1661135994559-03#]",
  "chargeStationId": "[#param.chargeStationId#]",
  "maxChargeCurrent": "",
  "maxChargeVoltage": ""
};
//将两个对象合并
let resObj = {
...nodeParams,
...selectObjParams
}

对象合并

  1. 扩展运算符
  2. Object.assign()
let resObj=Object.assign({},selectObjParams,nodeParams);
//输出
{agv: '[#context.node.1661135994559-03#]', chargeStationId: '[#param.chargeStationId#]', maxChargeCurrent: '', maxChargeVoltage: '', chargeLevel: ''}

数组合并

  1. 扩展运算符合并
let arr1=['aa','bb','cc'];
let arr2=['aa','dd'];[...arr1,...arr2]
//输出
['aa', 'bb', 'cc', 'aa', 'dd']
  1. concat()方法合并

数组对象合并

当对象属性有相同的时候,会覆盖

arr1=[{name:'a',age:18},{name:'b',age:10},{name:'c',age:8}];
arr2=[{name:'dd',school:'xr'},{school:'xs'}];
let newArr=arr1.map((item,index)=>{
    return {...item,...arr2[index]}
});
```![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/366e3f29c05f4257995c22ca65c9500c.png)


  • 7
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
可以使用JavaScript的reduce()和concat()方法合并多层对象数组。以下是一个示例代码,它将合并具有相同ID属性的对象,并将它们的数量相加: ```javascript const arr1 = [{id: 1, name: 'A', count: 2}, {id: 2, name: 'B', count: 3}]; const arr2 = [{id: 1, name: 'A', count: 4}, {id: 3, name: 'C', count: 1}]; const mergedArr = [...arr1, ...arr2].reduce((acc, curr) => { const index = acc.findIndex(item => item.id === curr.id); if (index === -1) { return [...acc, curr]; } else { acc[index].count += curr.count; return acc; } }, []); console.log(mergedArr); // Output: [{id: 1, name: 'A', count: 6}, {id: 2, name: 'B', count: 3}, {id: 3, name: 'C', count: 1}] ``` 如果要合并多层对象数组,可以使用递归来处理每个子数组。以下是一个示例代码: ```javascript const arr1 = [{id: 1, children: [{id: 2, name: 'A', count: 2}]}, {id: 3, name: 'B', count: 3}]; const arr2 = [{id: 1, children: [{id: 2, name: 'A', count: 4}]}, {id: 4, name: 'C', count: 1}]; function mergeArrays(arr1, arr2) { const mergedArr = [...arr1, ...arr2].reduce((acc, curr) => { const index = acc.findIndex(item => item.id === curr.id); if (index === -1) { return [...acc, curr]; } else if (curr.children) { acc[index].children = mergeArrays(acc[index].children, curr.children); return acc; } else { acc[index].count += curr.count; return acc; } }, []); return mergedArr; } const result = mergeArrays(arr1, arr2); console.log(result); // Output: [{id: 1, children: [{id: 2, name: 'A', count: 6}]}, {id: 3, name: 'B', count: 3}, {id: 4, name: 'C', count: 1}] ``` 这个示例代码中,mergeArrays()函数使用递归来处理每个子数组,直到没有子数组为止。在每个子数组中,它再次使用reduce()方法合并具有相同ID属性的对象。如果当前对象具有子数组,则递归处理该子数组。否则,它将增加当前对象的数量。最终,该函数将返回合并后的数组。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值