js如何把下列数据处理成目标想要的数据 ?

js数据结构处理 后台返回的接口数据如下

{
    "result": [
        {
            "name": "参数1",
            "secondName": [
                "高度",
                "马赫数"
            ]
        },
        {
            "name": "参数2",
            "secondName": [
                "前向",
                "垂向",
                "侧向"
            ]
        },
        {
            "name": "参数3",
            "secondName": [
                "前向",
                "垂向",
                "侧向"
            ]
        },
        {
            "name": "参数4",
            "secondName": [
                "前向",
                "垂向",
                "侧向"
            ]
        },
        {
            "name": "参数5",
            "secondName": [
                "前向",
                "垂向",
                "侧向"
            ]
        },
        {
            "name": "参数6",
            "secondName": [
                "前向",
                "垂向",
                "侧向"
            ]
        }
    ],
    "success": true
}

想把res.result变成如下格式

js数据结构处理后台返回的接口数据如下

{
    "result": [
        {
            "name": "参数1",
            "secondName": ‘高度‘
        },
        {
            "name": "参数1",
            "secondName": ‘马赫数‘
        },
        {
            "name": "参数2",
            "secondName": "前向",
            
        },
        {
            "name": "参数2",
            "secondName": "垂向",
            
        },
        {
            "name": "参数2",
            "secondName": "侧向",
            
        },
        
    }

以此类推....

没有思路,求指点

阅读 537
2 个回答

reduce功能很强大,可以学习下

result.reduce((arr, item) => arr.concat(item.secondName.map((sitem, sindex) => ({name: item.name, secondName: sitem, index: arr.length + sindex}))), [])
let originalData = {
    "result": [
        {
            "name": "参数1",
            "secondName": [
                "高度",
                "马赫数"
            ]
        },
        {
            "name": "参数2",
            "secondName": [
                "前向",
                "垂向",
                "侧向"
            ]
        },
        {
            "name": "参数3",
            "secondName": [
                "前向",
                "垂向",
                "侧向"
            ]
        },
        {
            "name": "参数4",
            "secondName": [
                "前向",
                "垂向",
                "侧向"
            ]
        },
        {
            "name": "参数5",
            "secondName": [
                "前向",
                "垂向",
                "侧向"
            ]
        },
        {
            "name": "参数6",
            "secondName": [
                "前向",
                "垂向",
                "侧向"
            ]
        }
    ],
    "success": true
};

let transformedData = {
    result: []
};

for (let item of originalData.result) {
    for (let name of item.secondName) {
        transformedData.result.push({
               name: item.name,
            secondName: name
        });
    }
}

console.log(transformedData);

image.png

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏