如何用JS将嵌套数组数据转换为指定键值对格式?

如何用js将嵌套数组数据转换为指定键值对格式?

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转换代码:

以下代码利用reducemap方法实现数据转换:

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元素创建一个新的对象,包含namesecondname属性。concat方法将新创建的对象添加到accumulator数组中。最终,reduce方法返回一个包含所有转换后对象的数组。

这段代码清晰地展示了如何使用reducemap方法高效地处理嵌套数组数据,并将其转换为所需的键值对格式。 这种方法比使用循环更加简洁易读。

以上就是如何用JS将嵌套数组数据转换为指定键值对格式?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1501998.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 00:04:08
下一篇 2025年12月20日 00:04:14

相关推荐

发表回复

登录后才能评论
关注微信