Heim > Web-Frontend > js-Tutorial > Wie sortiere ich ein JavaScript-Array basierend auf der Reihenfolge eines anderen Arrays, ohne IDs zu verwenden?

Wie sortiere ich ein JavaScript-Array basierend auf der Reihenfolge eines anderen Arrays, ohne IDs zu verwenden?

Susan Sarandon
Freigeben: 2024-12-12 11:46:13
Original
990 Leute haben es durchsucht

How to Sort a JavaScript Array Based on Another Array's Order Without Using IDs?

Sortieren Sie ein JavaScript-Array basierend auf der Reihenfolge eines anderen Arrays ohne IDs

Stellen Sie sich das folgende Szenario vor: Sie haben zwei Arrays, itemsArray und sortingArr. itemsArray enthält Name-Buchstaben-Paare wie ['Anne', 'a'], während sortingArr die gewünschte Buchstabenreihenfolge angibt, zum Beispiel ['b', 'c', 'b', 'b', 'a', 'd'].

Das Ziel besteht darin, itemsArray so neu anzuordnen, dass seine Reihenfolge so weit wie möglich mit der von sortingArr übereinstimmt, obwohl eindeutige Bezeichner fehlen.

Eins Eine elegante und effiziente Möglichkeit, dies zu erreichen, ist die Sortiermethode:

itemsArray.sort(function(a, b){  
  return sortingArr.indexOf(a) - sortingArr.indexOf(b);
});
Nach dem Login kopieren

In diesem Snippet verwendet die Sortiermethode eine benutzerdefinierte Vergleichsfunktion, um jedes Element im itemsArray zu vergleichen. Die Funktion gibt die Differenz zwischen dem Index des aktuellen Elements in sortingArr und dem Index des anderen Elements zurück. Durch diesen Vergleich wird sichergestellt, dass Elemente mit demselben Buchstaben gruppiert und nach sortingArr sortiert werden.

Das Ausgabe-ItemArray wird wie folgt neu angeordnet:

[
  ["Bob", "b"],
  ["Jason", "c"],
  ["Henry", "b"],
  ["Thomas", "b"]
  ["Anne", "a"],
  ["Andrew", "d"],
]
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie sortiere ich ein JavaScript-Array basierend auf der Reihenfolge eines anderen Arrays, ohne IDs zu verwenden?. 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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage