JavaScript ist eine High-Level-Programmiersprache, die zum Hinzufügen interaktiver und dynamischer Inhalte zu Webseiten verwendet wird. Unter anderem ist die Möglichkeit, Datentypen zu manipulieren, einer der Gründe, warum JavaScript so beliebt und wichtig ist. Wenn wir Daten verarbeiten, müssen wir häufig Elemente in einer Sammlung hinzufügen, lesen und löschen. Wenn ein Benutzer beispielsweise mit der Maus über ein Bild auf einer Seite fährt, müssen wir das Bild möglicherweise dynamisch aus einer Bildersammlung (z. B. einem Array) löschen, damit der Benutzer das Bild nicht mehr sieht, wenn die Maus darüber fährt Die Sammlung wurde erneut entfernt. Für solche Anforderungen bietet JavaScript mehrere Methoden zum Löschen von Elementen, die im Folgenden einzeln vorgestellt werden.
Die Methode splice() ist eine Methode, die das ursprüngliche Array ändern kann. Sie kann Elemente in das Array einfügen oder löschen und das Wertearray des gelöschten Elements zurückgeben. Diese Methode akzeptiert zwei oder mehr Parameter. Der erste Parameter gibt die Position des zu löschenden oder einzufügenden Startelements an, und der zweite Parameter gibt die Anzahl der zu löschenden oder einzufügenden Elemente an. Wenn Sie nur ein Element löschen möchten, können Sie nur einen Parameter übergeben.
let myArray = ["apple", "banana", "orange", "pear"]; myArray.splice(2, 1); // 第一个参数是要删除元素的位置,第二个参数是要删除的元素数量。 console.log(myArray); // ["apple", "banana", "pear"]
In diesem Code definieren wir ein Array myArray, das vier Fruchtnamen enthält. Verwenden Sie dann die Methode splice() und übergeben Sie den zweiten Parameter 1, der nur ein Element löschen soll. Der erste Parameter ist 2, was bedeutet, dass der Löschvorgang beim dritten Element beginnt, dh „Orange“ im Array löschen soll . Die endgültige Ausgabe zeigt, dass der Löschvorgang erfolgreich war und myArray nur drei Elemente enthält: „Apfel“, „Banane“ und „Birne“.
Das Schlüsselwort „delete“ kann auch zum Löschen von Elementen verwendet werden, funktioniert jedoch nur bei Objekteigenschaften und nicht bei Elementen in Arrays. Wenn Sie ein Array-Element mit dem Schlüsselwort delete löschen, wird der Wert des Elements einfach auf undefiniert gesetzt. Die Länge des ursprünglichen Arrays ändert sich nicht. Wenn Sie also tatsächlich ein Element aus dem Array entfernen möchten, müssen Sie die Methode splice() erneut aufrufen.
let myArray = ["apple", "banana", "orange", "pear"]; delete myArray[2]; console.log(myArray); // ["apple", "banana", undefined, "pear"]
In diesem Code verwenden wir das Schlüsselwort delete, um das dritte Element des myArray-Arrays, „orange“, zu löschen. Dieses Array wird jedoch zu [ „Apfel“, „Banane“, undefiniert, „Birne“ ] und die Position des gelöschten Elements wird undefiniert. Dies ist viel schlimmer, als es nicht zu löschen, da es sich nicht nur um ein ungültiges Element handelt, sondern auch Probleme beim Durchlaufen des Arrays verursacht. Daher wird empfohlen, niemals Elemente aus einem Array mit delete zu entfernen.
Die Array-Methode filter() in JavaScript kann verwendet werden, um Elemente in einem Array zu filtern und alle Instanzen von Elementen zurückzugeben, die einer bestimmten Bedingung entsprechen. Da die filter()-Methode im Vergleich zur splice()-Methode das ursprüngliche Array nicht ändert, tritt bei der Verwendung der filer()-Methode zum Löschen von Elementen nicht das Problem auf, einige Elemente zu ändern, die Sie nicht ändern möchten.
let myArray = ["apple", "banana", "orange", "pear"]; myArray = myArray.filter(function (item) { return item !== "orange"; // 返回所有不是“orange”元素的数组实例 }); console.log(myArray); // ["apple", "banana", "pear"]
In diesem Code definieren wir ein Array myArray, das vier Fruchtnamen enthält. Verwenden Sie dann die Methode filter() und übergeben Sie eine anonyme Funktion, die die Bedingungen zum Löschen von Elementen angibt. Diese anonyme Funktion gibt ein neues Array zurück, das alle Instanzen enthält, die keine „orangefarbenen“ Elemente sind. Diese Methode kann nicht nur ein Element, sondern auch mehrere Elemente löschen. Endlich haben wir ein aktualisiertes myArray, das das „orange“-Element nicht mehr enthält.
Die Methode „pop()“ oder „shift()“ wird zum Löschen von Elementen in einem Array verwendet. Die Methode „pop()“ löscht das letzte Element im Array, während die Methode „shift()“ das erste Element im Array löscht. Wenn wir die Position des zu entfernenden Elements in der Sammlung kennen, können wir diese verwenden, um ein bestimmtes Element zu entfernen. Dadurch wird das Element im Array jedoch nicht direkt gelöscht, sondern es wird lediglich ein neues Array gelöscht, das das Zielelement enthält. Wenn Sie das ursprüngliche Array ändern müssen, können Sie splice() aufrufen, um es zu ersetzen.
let myArray = ["apple", "banana", "orange", "pear"]; myArray.pop(); // 删除 myArray 中的最后一个元素 console.log(myArray); // ["apple", "banana", "orange"] myArray.shift(); // 删除 myArray 中的第一个元素 console.log(myArray); // ["banana", "orange"]
In diesem Code definieren wir ein Array myArray, das vier Fruchtnamen enthält. Dann löschen wir das letzte und erste Element im Array mit den Methoden pop() bzw. shift(). Beim Aufruf dieser Methoden wird das ursprüngliche Array geändert und auf die entfernten Elemente kann nicht zugegriffen werden. Wenn Sie das Array ändern müssen, müssen Sie daher zuerst eine Kopie erstellen.
Zusammenfassend lässt sich sagen, dass es in JavaScript mehrere Möglichkeiten gibt, Elemente aus einem Array zu löschen, und jede Methode hat ihre eigenen Vor- und Nachteile. splice() ist eine der am häufigsten verwendeten Methoden. Sie kann das ursprüngliche Array direkt ändern und den gelöschten Elementwert zurückgeben. Wenn wir das Array jedoch nicht ändern möchten, können wir filter () verwenden, aber diese Methode kann das ursprüngliche Array nicht direkt ändern. Die konkrete Auswahl der Löschmethode muss auf der Grundlage spezifischer Geschäftsanforderungen festgelegt werden.
Das obige ist der detaillierte Inhalt vonSo löschen Sie Array-Elemente in Javascript. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!