Heim > Web-Frontend > js-Tutorial > Wie kann ich Objekte in einem Array basierend auf einer gemeinsamen Eigenschaft gruppieren?

Wie kann ich Objekte in einem Array basierend auf einer gemeinsamen Eigenschaft gruppieren?

DDD
Freigeben: 2024-12-23 00:35:26
Original
902 Leute haben es durchsucht

How Can I Group Objects in an Array Based on a Common Property?

Objekte nach einer gemeinsamen Eigenschaft gruppieren

Problem:

Sie haben ein Array von Objekten, wobei jedes Objekt ein „ Gruppe“-Eigenschaft. Sie möchten dieses Array in ein neues Array umwandeln, in dem ähnliche „Gruppen“-Eigenschaftswerte gruppiert werden.

Gewünschte Ausgabe:

myArray = [
  {group: "one", color: ["red", "green", "black"]},
  {group: "two", color: ["blue"]}
]
Nach dem Login kopieren

Lösung:

  1. Erstellen Sie eine Zuordnung von Gruppennamen zum Leeren Arrays:
var group_to_values = {};
Nach dem Login kopieren
  1. Iterieren Sie über das Eingabearray:
myArray.forEach(function (item) {
    group_to_values[item.group] = group_to_values[item.group] || [];
});
Nach dem Login kopieren
  1. Erstellen Sie für jeden Schlüssel in der Zuordnung ein Objekt mit dem Gruppenname und ein Array von Werten:
var groups = [];
for (var key in group_to_values) {
    groups.push({group: key, color: group_to_values[key]})
}
Nach dem Login kopieren
  1. Das resultierende Gruppenarray wird nach gruppiert die Eigenschaft „Gruppe“.

Das obige ist der detaillierte Inhalt vonWie kann ich Objekte in einem Array basierend auf einer gemeinsamen Eigenschaft gruppieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage