我需要一点帮助来解决一个问题,我想看看是否有人能帮我:
我有一个对象,格式如下:
{
red: [
{time: "00:00:05", value: "7"},
{time: "00:00:10", value: "3"}],
green: [
{time: "00:00:05", value: "3"},
{time: "00:00:10", value: "27"}]
}我需要做的是:
它的外观示例:
{
red: [
{time: "00:00:05", value: "7", share: "70%"},
{time: "00:00:10", value: "3", share: "10%"}],
green: [
{time: "00:00:05", value: "3", share: "30%"},
{time: "00:00:10", value: "27", share: "90%"}]
}有人能帮我吗?我不能这么做。
发布于 2019-07-03 17:54:06
简短而简单的解决方案:
const o = {
red: [
{time: "00:00:05",value: "7"},
{time: "00:00:10",value: "3"}
],
green: [
{time: "00:00:05",value: "3"},
{time: "00:00:10",value: "27"}
]
};
const colors = Object.keys(o);
// saves the sum of all values, for each time
const total = o[colors[0]]
.map(x => x.time)
.map(time => colors
.map(c => +o[c].find(x => x.time == time).value)
.reduce((a, b) => a + b, 0)
);
// adds the 'share' property
colors.forEach(c => o[c].forEach((x, i) => o[c][i].share = `${Math.floor(100*x.value/total[i])}%`))
console.log(o);
发布于 2019-07-03 17:32:42
我想出了这个愚蠢的技术,但你还可以尝试更多。
我将将所有数据分组到一个数组中,但保留objectKey (红色、绿色或其他任何数据)和indexKey作为Symbol(),这样就不会出现任何名称干扰。
let data = {
red: [
{time: "00:00:05", value: "7", share: "70%"},
{time: "00:00:10", value: "3", share: "10%"}
],
green: [
{time: "00:00:05", value: "3", share: "30%"},
{time: "00:00:10", value: "27", share: "90%"}
]
}
let temp = [], objectKey = Symbol("object"), indexKey = Symbol("index")
for(let object in data) {
temp = [ ...temp, ...data[object].map((x, index) => ({ ...x, [objectKey]: object, [indexKey]: index }))]
}temp将如下所示:
[
{time: "00:00:05", value: "7", [objectKey]: "red", [indexKey]: 0},
{time: "00:00:10", value: "3", [objectKey]: "red", [indexKey]: 1}
{time: "00:00:05", value: "3", [objectKey]: "green", [indexKey]: 0},
{time: "00:00:10", value: "27", [objectKey]: "green", [indexKey]: 1}
]现在,我将按时间分组所有数据:
let temp2 = temp.reduce((r, a) => (r[a.time] = r[a.time] || [], r[a.time].push(a), r), {});所以我们得到了这样的temp2:
{
"00:00:05": [
{time: "00:00:05", value: "7", [objectKey]: "red", [indexKey]: 0},
{time: "00:00:05", value: "3", [objectKey]: "green", [indexKey]: 0},
],
"00:00:10": [
{time: "00:00:10", value: "3", [objectKey]: "red", [indexKey]: 1}
{time: "00:00:10", value: "27", [objectKey]: "green", [indexKey]: 1}
]
}现在我可以得到每个组的和,得到所需的百分比,并将其保存到正确的位置:
for(let time in temp2) {
let sum = temp2[time].reduce((r, a) => (r + parseInt(a.value)), 0)
temp2[time].forEach(e => (data[e[objectKey]][e[indexKey]].share = (e.value / sum * 100) + "%"))
}https://stackoverflow.com/questions/56874733
复制相似问题