javascript - 如何在javascript中过滤和修改数组中的每个对象?
问题描述
我正在开发一个小 webapp,它从 api 接收一组对象,然后在向每个对象添加一些数据并删除其他对象后在页面上显示结果。
如果当前索引元素与下一个元素相同,我已经通过 chechink 尝试过,但由于某种原因它不起作用。
const initialArray = [
{ x: 'one', y: 'place1'},
{ x: 'one', y: 'place1'},
{ x: 'two', y: 'place2'},
{ x: 'three', y: 'place3'},
{ x: 'three', y: 'place3'},
{ x: 'three', y: 'place3'},
{ x: 'four', y: 'place4'}
]
预期的结果应该是:
let resArray = [
{ x: 'one' , y: 'place1', count: 2},
{ x: 'two', y: 'place2', count: 1 },
{ x: 'three', y: 'place3', count: 3 },
{ x: 'four', y: 'place4', count: 1 }
]
控制台没有给出任何错误,所以这意味着我的算法不正确。感谢您的支持
解决方案
您可以使用reduce()
const initialArray = [
{ x: 'one', y: 'place1'},
{ x: 'one', y: 'place1'},
{ x: 'two', y: 'place2'},
{ x: 'three', y: 'place3'},
{ x: 'three', y: 'place3'},
{ x: 'three', y: 'place3'},
{ x: 'four', y: 'place4'}
];
const res = initialArray.reduce((ac,{x,y}) => {
let k = `${x}_${y}`
if(!ac[k]) ac[k] = {x,y,count:0};
ac[k].count++;
return ac;
},{})
console.log(Object.values(res))
推荐阅读
- javascript - Javascript解析错误令牌(详情如下)
- bash - Bash 脚本忽略传递文件中的空行+注释
- java - java如何选择.JAR库版本
- javascript - 构造函数内的 img.width/height 返回零
- jquery - Owl Carousel 2 不可见但没有错误
- javascript - Javascript:如何将嵌套的字符串数组拆分为数字
- python - 当python中所有列表的所有维度都未知时,在列表列表中追加项目
- linux - 用 BASH 中另一个文件中的字符串替换一个文件中的字符串
- r - 创建一个 PRNG 引擎
在 C++11 中匹配 PRNG 的结果是 R - swift - Swift 中的 Guard 对 if 给出不同的答案