Heim >Web-Frontend >js-Tutorial >Wie entferne ich effizient Elemente aus einem Array, das auf einem anderen Array in JavaScript basiert?

Wie entferne ich effizient Elemente aus einem Array, das auf einem anderen Array in JavaScript basiert?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-10-25 11:24:30773Durchsuche

How to Efficiently Remove Elements from an Array Based on Another Array in JavaScript?

Effizientes Entfernen von Elementen basierend auf einem anderen Array [Duplikat]

In JavaScript können Elemente aus einem Array entfernt werden, die in einem anderen Array vorhanden sind eine Herausforderung sein. Ein häufig verwendeter Ansatz besteht darin, die Methoden grep() und inArray() von jQuery zu verwenden. Es gibt jedoch reine JavaScript-Lösungen, die das gleiche Ergebnis ohne Schleifen oder Spleißen erzielen können.

Eine Methode besteht darin, die Methode Array.filter() zu verwenden, die das Array durchläuft und Elemente basierend auf einem angegebenen Wert herausfiltert Zustand. In diesem Fall ist die Bedingung, ob das Element nicht im toRemove-Array vorhanden ist.

<code class="javascript">myArray = myArray.filter(function(el) {
  return toRemove.indexOf(el) < 0;
});

Da sich die Browserunterstützung für Array.includes() verbessert hat, kann es zur weiteren Vereinfachung des Codes verwendet werden:

<code class="javascript">myArray = myArray.filter(function(el) {
  return !toRemove.includes(el);
});

Eine weitere Anpassung mithilfe von Pfeilfunktionen ergibt noch prägnanteren Code:

<code class="javascript">myArray = myArray.filter((el) => !toRemove.includes(el));</code>

Diese Methoden bieten eine effiziente und flexible Möglichkeit, Elemente aus einem Array basierend auf Kriterien zu entfernen, die in einem anderen Array ohne definiert sind die Notwendigkeit von Schleifen oder Array-Manipulationen.

Das obige ist der detaillierte Inhalt vonWie entferne ich effizient Elemente aus einem Array, das auf einem anderen Array in JavaScript basiert?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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