如何使用对象和数组优雅地将姓名和年龄数据分组?

如何使用对象和数组优雅地将姓名和年龄数据分组?

巧用对象和数组实现优雅数据转换

现有原始数据数组,包含姓名和年龄信息。为了便于展示,我们需要将数据转换为目标数据格式,即根据年龄对姓名进行分组。传统的数据循环转换方式可能较为繁琐。本文将介绍一种更优雅的转换方法。

解决方案

首先,使用一个临时对象对数据进行预处理。遍历原始数组,将姓名作为值,年龄作为键添加至对象中:

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;
});

这部分代码的作用如下:

  • 初始化目标数组中的一个新对象。
  • 遍历临时对象中的所有键,添加空字符串作为缺省值。
  • 找到匹配当前数组的年龄键,并将姓名添加到相应位置。

最终,目标数组即已生成的所需数据格式。通过这种方法,我们可以优雅高效地解决数据转换问题。

以上就是如何使用对象和数组优雅地将姓名和年龄数据分组?的详细内容,更多请关注其它相关文章!