js数组对象相同项合并处理

Posted ~零度~

tags:

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

平时工作中会经常遇到数据处理,其中数组合并处理也会经常遇到,下面就是数组相同项合并的一种方式:
1.首先由原始的数组arr数据,
2.然后创建一个map空对象和一个dest空数组,通过判断map中是否含有某项来判断数组dest是否添加数据,
3.然后再判断相同项和已有的dest数组内容比较合并;

代码如下:
<script type="text/javascript" src="js/jquery.min.js"></script>
<script>
$(function(){
  var arr = [
    {"id":"1","name":"张三","value":"1245"},
    {"id":"1","name":"张三","value":"1360"},
    {"id":"2","name":"李四","value":"1120"},
    {"id":"2","name":"李四","value":"1362"},
    {"id":"2","name":"李四","value":"1008"},
    {"id":"3","name":"王五","value":"1360"},
    {"id":"4","name":"赵六","value":"1986"},
    {"id":"4","name":"赵六","value":"1240"}
  ];
  var map = {},dest = [];
  for(var i = 0; i < arr.length; i++){
    var ai = arr[i];
    if(!map[ai.id]){
      dest.push({
        id: ai.id,
        name: ai.name,
        value: ai.value
      });
      map[ai.id] = ai;
    }else{
      for(var j = 0; j < dest.length; j++){
        var dj = dest[j];
        if(dj.id == ai.id){
          dj.value=(parseFloat(dj.value) + parseFloat(ai.value)).toString();
          break;
        }
      }
    }
  };
  console.log(dest);
})
</script>








































以上是关于js数组对象相同项合并处理的主要内容,如果未能解决你的问题,请参考以下文章

js 根据数组分组动态生成table(相同项合并)

js 数组对象根据相同value的key合并两个对象

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

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

js中怎么合并相同数组对象数据

在数组Vue Js中的另一个不同json对象中具有相同值的数组中的所有json对象中添加/合并新项目