該代碼的目標是生成一個新數組,該數組將10個或更多數字組分的所有標籤組合爲一個標籤爲V10+
的單個對象。新的對象值將是最大標籤的價值。避免在JavaScript中執行多個數組遍歷
在以下示例中,V13
是最偉大的標籤,因此將使用它的值:
[{'V10', 11}, {'V11', 123}, {'V12', 112}, {'V13', 120}] => {'V10+', 120}
目前我有到陣列上使用find
,map
然後reduce
。有沒有人有一個建議來簡化這個?
var someObjects = [
{'label': 'VS', 'value': 1 },
{'label': 'V1', 'value': 2 },
{'label': 'V2', 'value': 3 },
{'label': 'V3', 'value': 4 },
{'label': 'V4', 'value': 5 },
{'label': 'V5', 'value': 6 },
{'label': 'V6', 'value': 7 },
{'label': 'V7', 'value': 8 },
{'label': 'V8', 'value': 9 },
{'label': 'V9', 'value': 10 },
{'label': 'V10', 'value': 11 },
{'label': 'V11', 'value': 123 },
{'label': 'V12', 'value': 112 },
{'label': 'V13', 'value': 120 },
{'label': 'VE', 'value': 13 }
];
var maxObjVal = someObjects.find(function(obj) {
var max = Math.max.apply(null, someObjects.map(function (s) {
var labelNumber = s.label.substring(1);
return +labelNumber || 0;
}));
return obj.label == 'V' + max;
}).value;
var result = someObjects.reduce(function (ten) {
return function (r, a) {
var n = +a.label.substring(1);
if (n >= 10) {
if (!ten) {
ten = { label: 'V10+', value: maxObjVal };
r.push(ten);
}
} else {
r.push(a);
}
return r;
};
}(), []);
console.log('result: ' + JSON.stringify(result));
請發表您的代碼在這裏 – brk
您可以嘗試解釋以及代碼的目標。 –