Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/423.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/bash/18.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 将两个对象合并为一个,更新关键点_Javascript_Arrays_Object - Fatal编程技术网

Javascript 将两个对象合并为一个,更新关键点

Javascript 将两个对象合并为一个,更新关键点,javascript,arrays,object,Javascript,Arrays,Object,如何连接两个数组,更新“数量”键而不复制“标题”键 例如: obj1 obj2 我需要的输出: output = [ { id: 0, qty: 6, title: "HEINEKEN0 350ML" }, { id: 1, qty: 1, title: "HEINEKEN0 600ML" } ]; 您可以将两个数组连接在一起

如何连接两个数组,更新“数量”键而不复制“标题”键

例如:

obj1

obj2

我需要的输出:

output = [
    {
        id: 0,
        qty: 6,
        title: "HEINEKEN0 350ML"
    },
    {
        id: 1,
        qty: 1,
        title: "HEINEKEN0 600ML"
    }
 ];

您可以将两个数组连接在一起,并使用
Array#reduce
和一个对象来存储每个标题的值

const obj1=[{
id:0,
数量:1,
标题:“喜力350ML”
}],
obj2=[{
id:0,
数量:5,
标题:“喜力350ML”
},
{
id:1,
数量:1,
标题:“喜力600毫升”
}];
const res=Object.values([…obj1,…obj2])。reduce((acc,{title,qty,id})=>{
(acc[title]=acc[title]|{id,数量:0,title});
返回acc;
}, {}));

控制台日志(res)
我假定
obj1
obj2
实际上是对象的数组,而不是其名称所暗示的单个对象?当然,我在命名法上弄错了
obj2 = [
    {
        id: 0,
        qty: 5,
        title: "HEINEKEN0 350ML"
    },
    {
        id: 1,
        qty: 1,
        title: "HEINEKEN0 600ML"
    }
];
output = [
    {
        id: 0,
        qty: 6,
        title: "HEINEKEN0 350ML"
    },
    {
        id: 1,
        qty: 1,
        title: "HEINEKEN0 600ML"
    }
 ];