Heim > Web-Frontend > js-Tutorial > Wie kann ich bei Verwendung von Array.prototype.fill() eindeutige Objekte sicherstellen?

Wie kann ich bei Verwendung von Array.prototype.fill() eindeutige Objekte sicherstellen?

Mary-Kate Olsen
Freigeben: 2024-12-18 16:50:20
Original
259 Leute haben es durchsucht

How Can I Ensure Unique Objects When Using Array.prototype.fill()?

Array.prototype.fill(): Übergeben von Objekten als Referenzen

Die Methode Array.prototype.fill() ist ein praktisches Dienstprogramm für Initialisieren eines Arrays mit einem angegebenen Wert. Beim Füllen eines Arrays mit Objekten werden die Objekte jedoch als Referenzen übergeben, anstatt neue Instanzen zu erstellen. Dieses Verhalten wirft die Frage auf, ob es eine Möglichkeit gibt, sicherzustellen, dass jedes Element des Arrays ein eindeutiges Objekt ist.

Betrachten Sie das folgende Beispiel:

var arr = new Array(2).fill({});
console.log(arr[0] === arr[1]); // true
Nach dem Login kopieren

In diesem Beispiel zwei Objekte werden erstellt und als Verweise auf arr[0] und arr[1] übergeben. Das Ändern eines Elements des Arrays wirkt sich auf das andere aus, da es sich um dasselbe Objekt handelt:

arr[0].test = 'string';
console.log(arr[1].test); // 'string'
Nach dem Login kopieren

Um mit Array.prototype.fill() ein neues Objekt für jedes Element eines Arrays zu erstellen, können Sie wie folgt vorgehen Diese Schritte:

  1. Füllen Sie das Array mit einem beliebigen Wert (z. B. undefiniert) mithilfe der Methode fill().
  2. Verwenden Sie die map()-Methode zum Erstellen eines neuen Arrays mit neuen Instanzen des gewünschten Objekttyps:
var arr = new Array(2).fill().map(u => ({}));
Nach dem Login kopieren

Dieser Ansatz stellt sicher, dass jedes Element des Arrays ein eigenes, von den anderen isoliertes Objekt ist:

arr[0].test = 'string';
console.log(arr[1].test); // undefined
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie kann ich bei Verwendung von Array.prototype.fill() eindeutige Objekte sicherstellen?. 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