js篇章,数组合并其中属性值相同的项目且属性值相加

Posted 前端人

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js篇章,数组合并其中属性值相同的项目且属性值相加相关的知识,希望对你有一定的参考价值。

项目背景是:var a = [{id:1,num:"12"},{id:2,num:"13"},{id:3,num:"3"},{id:2,num:"16"},{id:5,num:"14"},{id:1,num:"14"}]

要求输出:a = [{id:1,num:"26"},{id:2,num:"29"},{id:3,num:"3"},{id:5,num:"14"}],id相同项合并且 num 相加,

现在想到的一个思路是双重循环a 数组,现将a 数组里面 id 相同项的 num 值相加,并记录id 相同项目的下标值(从后面记录),最后再删除相同项的下标,

代码截图为:

代码为:

var a = [{id:1,num:"12"},{id:2,num:"13"},{id:3,num:"3"},{id:2,num:"16"},{id:5,num:"14"},{id:1,num:"14"}]
		//要求输出 a = [{id:1,num:"26"},{id:2,num:"29"},{id:3,num:"3"},{id:5,num:"14"}],id相同项合并且 num 相加

		var b = []//记录数组a中的id 相同的下标
		for(var i = 0; i < a.length;i++){
			for(var j = a.length-1;j>i;j--){
				if(a[i].id == a[j].id){
					a[i].num = (a[i].num*1 + a[j].num*1).toString()
					b.push(j)
				}
			}

		}
		console.log(b)
		for(var k = 0; k<b.length;k++){
			a.splice(b[k],1)
		}
		console.log(a)

  

以上是关于js篇章,数组合并其中属性值相同的项目且属性值相加的主要内容,如果未能解决你的问题,请参考以下文章

js数组对象的相同值相加合并

js数组对象的相同值相加合并

js数组去重,id相同对某值相加合并

将数组内相同值的对象合并为一个新对象,并将其中一个值相加到新对象中,而且重复的对象则不能加到新对象

更改数组中对象的属性

javascript 数组对象根据相同属性值{key:value}合并两个对象