首页 > 解决方案 > 根据另一个数组中的键更新数组数据

问题描述

我想根据另一个数组中存在的键更新数组数据,如果键不存在,则输出值为 0 的数据以及相应的键

let data = [{
    ORIGEN: "WB716594",
    "Gestor Ericsson OSS": 1
}, {
    ORIGEN: "MM-LORC-AGUI-L3-11_760525",
    "MM-LORC-AGUI-L3-11_760525": 1
}];

let keyValue = ["Gestor Ericsson OSS",
    "MM-LORC-AGUI-L3-11_760525",
    "Gestor HUA U2KVIA",
    "5620SAM"
]

此处的“Gestor HUA U2KVIA”和“5620SAM”不存在于数据中,因此应附加如下

Output = [{ORIGEN: "WB716594", Gestor Ericsson OSS: 1, "MM-LORC-AGUI-L3-11_760525":0,Gestor HUA U2KVIA:0,5620SAM:0},
 {ORIGEN: "MM-LORC-AGUI-L3-11_760525", MM-LORC-AGUI-L3-11_760525: 1,Gestor Ericsson OSS: 0,Gestor HUA U2KVIA:0,5620SAM:0}
 ]

标签: javascriptarraysobjectlodasharrayobject

解决方案


您可以创建一个以keyValue数组项为键和0值的对象。然后遍历data数组 usingmap和 useObject.assign以获取每个项目的合并对象:

const data = [{ORIGEN:"WB716594","Gestor Ericsson OSS":1},{ORIGEN:"MM-LORC-AGUI-L3-11_760525","MM-LORC-AGUI-L3-11_760525":1}],
     keyValue = ["Gestor Ericsson OSS","MM-LORC-AGUI-L3-11_760525","Gestor HUA U2KVIA","5620SAM"]

const defaultObj = Object.assign({}, ...keyValue.map(key => ({ [key]: 0 })));
const output = data.map(obj => Object.assign({}, defaultObj, obj));

console.log(output)


推荐阅读