Es gibt im JavaScript viele nützliche Array Funktionen aber wiederum gelten die nicht für Objekte. Das kann zum Beispiel ein Grund sein, warum man sich einer Object Funktion bedient um daraus ein Array zu machen. Ich stelle im Folgenden die Funktionen: Object.keys, Object.value und Object.entries vor.
Ausgangsituation wäre ein nettes Objekt:
const niceObject = {
2019: {visitors:1},
2020: {visitors:2},
2021: {visitors:4}
}
Das sind nämlich die Unique Besucher meiner Website und nun möchte ich errechnen wieviele Besucher ich seit 2019 hatte. Mit Array.reduce() wäre das im Handumdrehen gemacht. Aber mit einem Object. Wie geht den das?
Object.keys
Objekt.keys gibt uns alle Keys des Objektes als Array wieder.
const years = Object.keys(niceObject)
// output years
[2019, 2020, 2021]
Nun können wir mit der Arrayfunktion reduce() was anfangen. Ist doch ein Array.
const result = years.reduce((sum, key) => {
return sum + niceObject[key].visitors;
}, 0)
// output result
7
Object.values
Object.values gibt uns ein Array mit allen (drei Objekten) Values zurück.
const visitors = Object.values(niceObject)
// output visitors
[
{visitors: 1},
{visitors: 2},
{visitors: 4},
]
Deshalb können wir nun folgendes machen:
const result = visitors.reduce((sum, singleObject) => {
return sum + singleObject.visitors;
}, 0);
// output result
7
// Oder richtig kurz
const resultShortObject.values(niceObject).reduce((t, n) => t + n.visitors, 0)
// output resultShort
7
Object.entries
Object.entries gibt uns ein Array mit drei Arrays zurück.
const entriesArray = Object.entries(niceObject)
// output entriesArray
[
["a", {visitors: 1}],
["b", {visitors: 2}],
["c", {visitors: 4}]
];
let result = entriesArray.reduce((sum, arr) => {
return sum + arr[1].visitors;
}, 0)
// output result
7
Also 7 Besucher in drei Jahren. Not bad! Aber ich war schon mal besser…
Bei alle drei Funktionen übergeben wir einen Parameter mit dem Wert 0. Dieser ist der Initial Wert.