数组合并和对象合并方法

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

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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)


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值