
JavaScript数据转换:将嵌套数组转换为指定键值对格式
在数据处理中,常常需要将复杂的数据结构转换为更易于使用的格式。本文将演示如何使用JavaScript将后台返回的嵌套数组数据转换为特定的键值对格式。
原始数据:
假设后台返回的接口数据如下:
<code class="json">{
"result": [
{
"name": "参数1",
"secondname": ["高度", "马赫数"]
},
{
"name": "参数2",
"secondname": ["前向", "垂向", "侧向"]
},
{
"name": "参数3",
"secondname": ["前向", "垂向", "侧向"]
}
],
"success": true
}</code>目标格式:
我们需要将其转换为以下格式:
<code class="json">{
"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": "侧向" }
]
}</code>JavaScript转换代码:
以下代码利用reduce和map方法实现数据转换:
<code class="javascript">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));</code>代码解释:
reduce方法迭代originalData.result数组中的每个对象。map方法迭代每个对象中的secondname数组,为每个secondname元素创建一个新的对象,包含name和secondname属性。concat方法将新创建的对象添加到accumulator数组中。reduce方法返回一个包含所有转换后对象的数组。这段代码清晰地展示了如何使用reduce和map方法高效地处理嵌套数组数据,并将其转换为所需的键值对格式。 这种方法比使用循环更加简洁易读。
以上就是如何用JS将嵌套数组数据转换为指定键值对格式?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号