使用此示例对象数组:
[{
"Element ID": "299",
"Element Name": "Manager",
"Scale ID": "IM",
"Data Value": "3.5"
},
{
"Element ID": "299",
"Element Name": "Manager",
"Scale ID": "LV",
"Data Value": "3"
},
{
"Element ID": "300",
"Element Name": "FinTech",
"Scale ID": "IM",
"Data Value": "1.75"
},
{
"Element ID": "300",
"Element Name": "FinTech",
"Scale ID": "LV",
"Data Value": "1.38"`
}]
我写了这段代码来合并重复的对象Element ID
并重命名一些元素:
let p = {};
const output = input
.map(s => {
if (_.isEmpty(p)) {
p = s;
return {};
}
if (p['Element ID'] !== s['Element ID']) return {};
const result = {
name: s['Element Name'],
id: s['Element ID'],
importance:
p['Scale ID'] === 'IM'
? p['Data Value']
: s['Scale ID'] === 'IM'
? s['Data Value']
: null,
level:
p['Scale ID'] === 'LV'
? p['Data Value']
: s['Scale ID'] === 'LV'
? s['Data Value']
: null,
};
p = {};
return result;
})
.filter(n => Object.keys(n).length);
所以它现在输出所需的格式:
[{
"name": "Manager",
"id": "299",
"importance": "3.5",
"level": "3"
},
{
"name": "FinTech",
"id": "300",
"importance": "1.75",
"level": "1.38"
}]
这是一种复杂的方法,如果输入对象数组在数组中没有完全相邻的两个相似对象,则该方法会失败。有没有更好的方法通过lodash
,.reduce()
或我没有考虑的类似方法?
试试这个:
const resultObject = originalArray.reduce((result, element) => {
const id = element["Element ID"];
const resultElement = result[id] || {
id,
name: element["Element Name"],
};
switch (element["Scale ID"]) {
case "LV":
resultElement.level = element["Data Value"] || null;
break;
case "IM":
resultElement.importance = element["Data Value"] || null;
break;
}
return {
...result,
[id]: resultElement,
}
}, {});
const resultArray = Object.keys(resultObject).reduce((result, key) => ([
...result,
{
"id": key,
...resultObject[key],
}
]), []);
originalArray
是你的数据。
您可以通过将键移动到常量来改进这一点。试着让你的代码可读。算法没那么复杂。避免将库用于这样的简单任务。Javascript 已经非常强大了。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句