巧用对象和数组实现优雅数据转换
现有原始数据数组,包含姓名和年龄信息。为了便于展示,我们需要将数据转换为目标数据格式,即根据年龄对姓名进行分组。传统的数据循环转换方式可能较为繁琐。本文将介绍一种更优雅的转换方法。
首先,使用一个临时对象对数据进行预处理。遍历原始数组,将姓名作为值,年龄作为键添加至对象中:
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; });
这部分代码的作用如下:
最终,目标数组即已生成的所需数据格式。通过这种方法,我们可以优雅高效地解决数据转换问题。