
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方法高效地处理嵌套数组数据,并将其转换为所需的键值对格式。 这种方法比使用循环更加简洁易读。
以上就是如何用JS将嵌套数组数据转换为指定键值对格式?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1501998.html
微信扫一扫
支付宝扫一扫