js计算数组中某个元素重复出现的个数

Posted 前进中的蜗牛

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js计算数组中某个元素重复出现的个数相关的知识,希望对你有一定的参考价值。

let list = [
  {name:"1000积分",serialNumber:6},
  {name:"500积分",serialNumber:7},
  {name:"50积分",serialNumber:8},
  {name:"50积分",serialNumber:8},
  {name:"50积分",serialNumber:8}
];

怎么把list数组转化为

[
  {title:"1000积分",num:1},
  {title:"500积分",num:1},
  {title:"50积分",num:3}
]
//num:serialNumber相同的元素重复次数

首先要先获取同样的serialNumber的重复次数

//先根据所有的serialNumber组合成一个数组
let titleList = list.map(item => {
return item.name
})
//获得["1000积分", "500积分", "50积分", "50积分", "50积分"]


然后有两种方法将titleList 转化
 // 不用reduce时:
function getRepeatNum(){ 
        var obj = {}; 
        for(var i= 0, l = titleList.length; i< l; i++){ 
            var item = arr[i]; 
            obj[item] = (obj[item] +1 ) || 1; 
        } 
        return obj; 
}

//用reduce时:
//reduce:计算数组元素相加后的总和
function getRepeatNum(){ 
        return titleList.reduce(function(prev,next){ 
            prev[next] = (prev[next] + 1) || 1; 
            return prev; 
        },{}); 
} 

console.log(getRepeatNum());//获得{1000积分: 1, 500积分: 1, 50积分: 3}

let myObj = this.getRepeatNum2(titleList),
winningList = []
for(let i in myObj){
let obj = {
title:i,
num:myObj[i]
}
winningList.push(obj)
}
console.log(winningList)
//[{"title":"1000积分","num":1},{"title":"500积分","num":1},{"title":"50积分","num":3}]

 

以上是关于js计算数组中某个元素重复出现的个数的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript笔试题(js高级代码片段)

js 一个数组各元素出现的次数,并输出,怎么写代码

javascript计算数组重复元素个数,并计算个数

js计算一个变量里面某个字段个数?

js数组的reduce方法能计算数组中每个元素出现的次数吗?

用python 一行代码去掉数组中重复元素