
JavaScript数据转换:将嵌套数组转换为指定键值对格式
在数据处理中,常常需要将复杂的数据结构转换为更易于使用的格式。本文将演示如何使用JavaScript将后台返回的嵌套数组数据转换为特定的键值对格式。
原始数据:
假设后台返回的接口数据如下:
{
"result": [
{
"name": "参数1",
"secondname": ["高度", "马赫数"]
},
{
"name": "参数2",
"secondname": ["前向", "垂向", "侧向"]
},
{
"name": "参数3",
"secondname": ["前向", "垂向", "侧向"]
}
],
"success": true
}
目标格式:
我们需要将其转换为以下格式:
{
"result": [
{ "name": "参数1", "secondname": "高度" },
{ "name": "参数1", "secondname": "马赫数" },
{ "name": "参数2", "secondname": "前向" },
{ "name": "参数2", "secondname": "垂向" },
{ "name": "参数2", "secondname": "侧向" },
{ "name": "参数3", "secondname": "前向" },
{ "name": "参数3", "secondname": "垂向" },
{ "name": "参数3", "secondname": "侧向" }
]
}
JavaScript转换代码:
以下代码利用reduce和map方法实现数据转换:
const originalData = {
"result": [
{
"name": "参数1",
"secondname": ["高度", "马赫数"]
},
{
"name": "参数2",
"secondname": ["前向", "垂向", "侧向"]
},
{
"name": "参数3",
"secondname": ["前向", "垂向", "侧向"]
}
],
"success": true
};
const transformedData = {
result: originalData.result.reduce((accumulator, currentItem) => {
return accumulator.concat(currentItem.secondname.map(secondNameItem => ({
name: currentItem.name,
secondname: secondNameItem
})));
}, [])
};
console.log(JSON.stringify(transformedData, null, 2));
代码解释:
-
reduce方法迭代originalData.result数组中的每个对象。 -
map方法迭代每个对象中的secondname数组,为每个secondname元素创建一个新的对象,包含name和secondname属性。 -
concat方法将新创建的对象添加到accumulator数组中。 - 最终,
reduce方法返回一个包含所有转换后对象的数组。
这段代码清晰地展示了如何使用reduce和map方法高效地处理嵌套数组数据,并将其转换为所需的键值对格式。 这种方法比使用循环更加简洁易读。










