如何使用对象和数组优雅地将姓名和年龄数据分组?
巧用对象和数组实现优雅数据转换
现有原始数据数组,包含姓名和年龄信息。为了便于展示,我们需要将数据转换为目标数据格式,即根据年龄对姓名进行分组。传统的数据循环转换方式可能较为繁琐。本文将介绍一种更优雅的转换方法。
解决方案
首先,使用一个临时对象对数据进行预处理。遍历原始数组,将姓名作为值,年龄作为键添加至对象中:
let temp = {}; arr.forEach(item => { if (!temp[item.age]) { temp[item.age] = []; } temp[item.age].push(item.name); });
接下来,将临时对象转换为目标数组。首先获取对象的所有值,即分别包含不同年龄组姓名的数组。然后对每个数组执行以下操作:
value.forEach((name, index) => { if (!targetArr[index]) { targetArr[index] = {}; } Object.keys(temp).forEach(key => { if (key in targetArr[index]) { return; } targetArr[index][key] = ''; }); targetArr[index][Object.keys(temp).find(key => temp[key] === value)] = name; });
这部分代码的作用如下:
- 初始化目标数组中的一个新对象。
- 遍历临时对象中的所有键,添加空字符串作为缺省值。
- 找到匹配当前数组的年龄键,并将姓名添加到相应位置。
最终,目标数组即已生成的所需数据格式。通过这种方法,我们可以优雅高效地解决数据转换问题。
以上就是如何使用对象和数组优雅地将姓名和年龄数据分组?的详细内容,更多请关注其它相关文章!