Heim > Web-Frontend > js-Tutorial > Wie entferne ich Objekte basierend auf Eigenschaften in JavaScript effizient aus einem Array?

Wie entferne ich Objekte basierend auf Eigenschaften in JavaScript effizient aus einem Array?

Barbara Streisand
Freigeben: 2024-10-30 08:59:39
Original
560 Leute haben es durchsucht

How to Efficiently Remove Objects from an Array Based on Properties in JavaScript?

Verwendung von nativem JavaScript zum Entfernen von Objekten aus einem Array nach Objekteigenschaften

Bei der Arbeit mit Arrays von Objekten kann das Entfernen bestimmter Objekte basierend auf Eigenschaften sinnvoll sein essentiell. Allerdings kann die einfache Verwendung von splice() aufgrund der abnehmenden Array-Länge zu Komplikationen führen. So lösen Sie dieses Problem mit nativen JavaScript-Techniken:

Dekrementieren von i nach dem Löschen:

Um das Problem mit Splice zu beheben, dekrementieren Sie i nach jedem Löschvorgang, um dies zu berücksichtigen verschobener Index. Dies verhindert das Überspringen von Array-Elementen und stellt sicher, dass alle Zielobjekte entfernt werden.

for (var i = 0; i < arrayOfObjects.length; i++) {
    var obj = arrayOfObjects[i];

    if (listToDelete.indexOf(obj.id) !== -1) {
        arrayOfObjects.splice(i, 1);
        i--;
    }
}
Nach dem Login kopieren

Array-Elemente neu schreiben:

Um lineare Löschvorgänge zu vermeiden, können Sie Folgendes tun Schreiben Sie nur die Elemente um, die Sie im Array behalten möchten.

var end = 0;

for (var i = 0; i < arrayOfObjects.length; i++) {
    var obj = arrayOfObjects[i];

    if (listToDelete.indexOf(obj.id) === -1) {
        arrayOfObjects[end++] = obj;
    }
}

arrayOfObjects.length = end;
Nach dem Login kopieren

Verwenden eines Hash-Sets:

Für schnellere Suchvorgänge verwenden Sie ein Hash-Set zum Speichern der IDs Anzahl der zu löschenden Objekte.

const setToDelete = new Set(listToDelete);
let end = 0;

for (let i = 0; i < arrayOfObjects.length; i++) {
    const obj = arrayOfObjects[i];

    if (setToDelete.has(obj.id)) {
        arrayOfObjects[end++] = obj;
    }
}

arrayOfObjects.length = end;
Nach dem Login kopieren

Wiederverwendbare Funktion:

Verpacken Sie diese Logik der Einfachheit halber in eine wiederverwendbare Funktion.

const filterInPlace = (array, predicate) => {
    let end = 0;

    for (let i = 0; i < array.length; i++) {
        const obj = array[i];

        if (predicate(obj)) {
            array[end++] = obj;
        }
    }

    array.length = end;
};

const toDelete = new Set(['abc', 'efg']);

const arrayOfObjects = [{id: 'abc', name: 'oh'},
                        {id: 'efg', name: 'em'},
                        {id: 'hij', name: 'ge'}];

filterInPlace(arrayOfObjects, obj => !toDelete.has(obj.id));
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie entferne ich Objekte basierend auf Eigenschaften in JavaScript effizient aus einem Array?. 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