Indexierte Sammlungen

Eine indexierte Sammlung ist eine Datenstruktur, in der Elemente gespeichert und Zugriff über nummerierte Indexe. In einer indexierten Sammlung gespeicherte Werte: zugewiesenen nummerierten Indexen beginnend bei 0, einem Muster namens „Null-Indexierung“. Sie können dann auf die in einer indexierten Sammlung gespeicherten Werte zugreifen, indem Sie ihre Indexe.

Ein Array ist ein Container, der null oder mehr Werte eines beliebigen Datentyps enthalten kann. einschließlich komplexer Objekte und Arrays. In einem Array gespeicherte Werte sind manchmal als „Elemente“ bezeichnet des Arrays an.

Wie bei primitiven Datentypen gibt es zwei Ansätze zum Erstellen eines Arrays: Ein Arrayliteral oder durch Aufrufen des integrierten Array()-Konstruktors von JavaScript mit new Array(). Das Zuweisen eines Arrays zu einer Variablen ermöglicht eine hohe Portabilität und iterable Art der Zuweisung mehrere Werte in eine einzige Kennung.

Bei der Array-Literalsyntax werden 0 oder mehr von eckigen Klammern ([]) verwendet kommagetrennte Datenwerte:

const myArray = [];

In der Syntax des Array-Konstruktors wird das integrierte Array-Objekt von JavaScript als -Konstruktor mit dem Schlüsselwort new:

const myArray = new Array();

Sowohl mit der Array-Literal- als auch mit der Array-Konstruktorsyntax können Sie ein Array mit Informationen erhalten, auch wenn sich die Syntax geringfügig in der Art und Weise unterscheidet, definiert sind. Bei der Syntax des Arrayliterals werden kommagetrennte Werte zwischen den eckige Klammern zu, was genauso aussieht wie das resultierende Array:

const myArray = [ true, null, "String", false ];

myArray;
> [ true, null, "String", false ]

Die Arraykonstruktor-Syntax verwendet kommagetrennte Werte als Argumente, wobei ein Besondere verhaltensbezogene Ausnahme:

const myArray = new Array( true, null, "String", false );

myArray;
> Array(4) [ true, null, "String", false ]

Wenn ein einzelner numerischer Wert an den Konstruktor Array übergeben wird, nicht der nullten Position im resultierenden Array zugewiesen. Stattdessen wird ein Array mit dieser Anzahl von leeren Slots für Werte erstellt. Dies erzwingt keine für das Array. Elemente können auf die gleiche Weise hinzugefügt und entfernt werden. wie bei einem Array-Literal.

// Firefox:\
const myArray = new Array( 10 );

myArray;
> Array(10) [ <10 empty slots> ]
// Chrome:
const myArray = new Array( 10 );

myArray;
> (10) [empty × 10]

Arrays mit leeren Slots (manchmal als "dünnbesetzte Arrays" bezeichnet) sind etwas Besonderes. Cases. Anstelle eines undefined- oder expliziten null-Werts, leer werden oft, aber nicht immer, an anderer Stelle imundefined Sprache.

Sie können versehentlich ein dünnbesetztes Array mit der Arrayliteral-Syntax erstellen, indem Sie durch Auslassen eines Werts zwischen Kommas, wenn Sie ein Arrayliteral erstellen:

const myArray = [ true,, true, false ];

myArray;
> Array(4) [ true, <1 empty slot>, true, false ]

Auch wenn ein leerer Slot nicht in allen Kontexten als sinnvoller Wert behandelt wird, in die Gesamtlänge des Arrays eingerechnet wird, unerwartete Ergebnisse beim Iterieren über eines Arrays:

const myArray = [ 1,, 3, 4 ];

myArray.length;
> 4

for( const myValue of myArray ) {
  console.log( myValue + 10 );
}
> 11
> NaN
> 13
> 14

Dieses Verhalten ist ein Ausnahmefall von einigen der ersten Designentscheidungen von JavaScript. Vermeiden Sie die Verwendung von dünnbesetzten Arrays in der modernen Entwicklung.

Wie bei Primitiven kann ein Array-Literal übernimmt Eigenschaften und Methoden vom entsprechenden Konstruktor. Da ein Array eine Sonderform eines Objekts ist, können die Array-Literal-Syntax new Array()-Syntax erzeugen funktionell identische Ergebnisse: ein Objekt, das übernimmt seinen Prototyp vom Array-Konstruktor.

const arrayLiteral = [];
const arrayConstructor = new Array();

typeof arrayLiteral;
> "object"

arrayLiteral;
> Array []
    length: 0
    <prototype>: Array []

typeof arrayConstructor;
> "object"

arrayConstructor;
> Array []
    length: 0
    <prototype>: Array []

Weil die beiden Ergebnisse identisch sind und die Array-Literal-Syntax kürzer ist. und literal verwenden, empfehlen wir dringend, immer die Array-Literal-Syntax new Array()-Syntax.

Auf Arraywerte zugreifen

Sie können auf einzelne Elemente innerhalb des Arrays zugreifen, indem Sie Klammer-Notation, Reihe von Klammern ([]) hinter dem Array oder seiner Kennung, die einen Nummer, die sich auf den Index dieses Elements bezieht:


[ "My string", "My other string" ][ 1 ];
> "My other string"

const myArray = [ "My string", 50, true ];

myArray[ 0 ];
> "My string"

myArray[ 1 ];
> 50

myArray[ 2 ];
> true

Arrays in JavaScript sind nicht assoziativ, Sie können also keinen beliebigen String als Index verwenden. Die numerischen Werte -Werte, die für den Zugriff auf Elemente in einem Array verwendet werden, in einen String-Wert hinter die Szenen aus, was bedeutet, dass Sie einen Zeichenfolgenwert verwenden können, der nur numerische Zeichen:

const myArray = [ "My string", 50, true ];

myArray[ 2 ];
> true

myArray[ "2" ];
> true

Der Versuch, auf ein Element außerhalb der im Array definierten Elemente zuzugreifen, führt zu undefined ist kein Fehler:

const myArray = [ "My string", 50, true ];

myArray[ 9 ];
> undefined

Zuweisung wird gelöscht

Das destruktive Zuweisung ist eine prägnante Methode, um eine Reihe von Werten Arrays oder Objekten zu erstellen und diese einer Reihe von ein Prozess, der manchmal als „Entpacken“ bezeichnet wird, der ursprünglichen Datenstruktur, auch wenn das ursprüngliche Array oder Objekt nicht geändert wird.

Beim Löschen der Zuweisung wird eine Array- oder objektähnliche Liste von IDs verwendet, Werte zu verfolgen. In seiner einfachsten Form, dem Bindungsmuster, -destruktiv wird jeder Wert aus dem Array oder Objekt entpackt und einer entsprechende Variable, die mit let oder const (oder var) initialisiert wurde:

const myArray = [ "A string", "A second string" ];
const [ myFirstElement, mySecondElement ] = myArray;

const myObject = { firstValue: false, secondValue: true };
const { myProp, mySecondProp } = myObject;

myFirstElement;
> "My string"

mySecondElement;
> "Second string"

myProp;
> false

mySecondProp;
> true

Verwenden Sie geschweifte Klammern ({}), um die Struktur eines Objekts zu destrukturieren, und eckige Klammern ([]), um ein Array zu destrukturieren.

const myArray = [ false, true ];
const myObject = { firstValue: false, secondValue: true };

const [ myProp, mySecondProp ] = myObject;
> Uncaught TypeError: myObject is not iterable

const { myElement, mySecondElement } = myArray;

myElement
> undefined

mySecondElement;
> undefined

Arrays werden in sequenzieller Reihenfolge von links nach rechts zerstört. Jedes in der destruktiven Zuweisung entspricht dem Element des Array mit demselben Index:

const myArray = [ 1, 2, 3 ];
const [ myElement, mySecondElement, myThirdElement ] = myArray;

myElement;
> 1

mySecondElement;
> 2

myThirdElement;
> 3

Dies ist auch das Standardverhalten beim Löschen eines Objekts. Wenn die IDs, die in der destruktiven Zuweisung verwendet werden, stimmen mit den Schlüsseln der enthalten, werden diese IDs mit der entsprechenden Property unabhängig von ihrer angegebenen Reihenfolge:

const myObject = { firstValue: 1, secondValue: 2, thirdValue 3 };
const { secondValue, thirdValue, firstValue } = myObject;

firstValue;
> 1

secondValue;
> 2

thirdValue;
> 3

Elemente können übersprungen werden, indem eine Kennung weggelassen wird:

const myArray = [ 1, 2, 3 ];
const [ firstValue,, secondValue ] = myArray;

firstValue;
> 1

secondValue;
> 3

Mit der destruktiven Syntax können Sie auch Standardwerte für den Fall einer value ist entweder ein leerer Slot, wie bei einem dünnbesetzten Array, oder ein undefined-Wert.

const myArray = [ true, ];
const [ firstValue = "Default string.", secondValue = "Default string." ] = myArray;

firstValue;
> true

secondValue;
> "Default string."

Bei der Dekonstruktion werden Werte nicht in bestimmte Typen umgewandelt. Das bedeutet, dass "falsy"-Werte wie leer ("") oder null werden trotzdem als sinnvolle dekonstruierte Werte betrachtet:

const myArray = [ false, null, 0, "",, undefined ];
const [ falseValue = true, nullValue = true, zeroValue = true, emptyStringValue = true, emptySlot = true, undefinedValue = true ] = myArray;

falseValue;
> false;

nullValue;
> null

zeroValue;
> 0

emptyStringValue;
> ""

emptySlot;
> true

undefinedValue;
> true

Spread-Operator

Den in ES6 eingeführten Streuungsoperator (...) verwenden, um iterierbare Daten zu erweitern wie ein Array, ein String oder ein Objektliteral in einzelne Elemente umwandeln. Auf den Spread-Operator folgt unmittelbar die zu erweiternde Datenstruktur. bzw. die Kennung einer Variablen, die diese Datenstruktur enthält.

const myArray = [ 1, 2, 3 ];

console.log( ...myArray );
> 1 2 3

Die Spread-Syntax wird hauptsächlich zum Kopieren und Kombinieren von Arrays verwendet:

const myArray = [ 4, 5, 6 ];
const mySecondArray = [1, 2, 3, ...myArray ];

mySecondArray;
> Array(6) [ 1, 2, 3, 4, 5, 6 ]

Sie können die Streuungssyntax nur in den folgenden Kontexten verwenden:

Bei Arrays und Strings wird die Streuungssyntax nur angewendet, wenn null oder mehr Argumente vorhanden sind. in einem Funktionsaufruf oder Elemente in einem Array erwartet werden. Das erste Beispiel für Die Syntax des Spread-Operators in diesem Abschnitt funktioniert, da sie ...myArray als Ein Argument für die integrierte Methode console.log.

Beispielsweise können Sie die Daten, die verteilt werden, nicht einer Variablen außerhalb ein weiteres Array:

const myArray = [ 1, 2, 3 ];
const spreadVariable = ...myArray;
> Uncaught SyntaxError: Unexpected token '...'

Zum Kopieren eines Arrays verteilen Sie das ursprüngliche Array jedoch in ein Arrayliteral:

const myArray = [ 1, 2, 3 ];
const spreadArray = [ ...myArray ];

spreadArray;
> Array(3) [ 1, 2, 3 ]

So führen Sie die Elemente, aus denen zwei oder mehr Arrays bestehen, zu einem einzigen Array zusammen:

const myArray = [ 1, 2, 3 ];
const mySecondArray = [ 4, 5, 6 ];
const myNewArray = [ ...myArray, ...mySecondArray ];

myNewArray;
> Array(6) [ 1, 2, 3, 4, 5, 6 ]

Oder , um Elemente eines Arrays als einzelne Argumente in einem Funktionsaufruf zu übergeben:

const myArray = [ true, false ];
const myFunction = ( myArgument, mySecondArgument ) => {
    console.log( myArgument, mySecondArgument );
};

myFunction( ...myArray );
> true false

Der Spread-Operator wurde erweitert, um mit Objektliteralen in ES2018. Wie bei Arrays können Sie den Streuungsoperator verwenden, um Objekte zu duplizieren oder zusammenzuführen:

const myObj = { myProperty : true };
const mySecondObj = { ...myObj };

mySecondObj;
> Object { myProperty: true }
const myFirstObj = { myProperty : true };
const mySecondObj = { additionalProperty : true };
const myMergedObj = { ...myFirstObj, ...mySecondObj };

myMergedObj;
> Object { myProperty: true, additionalProperty: true }

Der Streuungsoperator erstellt „oberflächlich“ Kopien. Das bedeutet, dass das Feld Prototyp des ursprünglichen Objekts und nicht aufzählbar Eigenschaften.

const myCustomPrototype = { protoProp: "My prototype." };
const myObj = Object.create( myCustomPrototype, {
    myEnumerableProp: {
        value: true,
        enumerable: true
    },
    myNonEnumerableProp: {
        value: false,
        enumerable: false
    }
});
const myNewObj = { ...myObj };

myObj;
> Object { myEnumerableProp: true,  }
    myEnumerableProp: true
    myNonEnumerableProp: false
    <prototype>: Object { protoProp: "My prototype." }

myNewObj;
> Object { myEnumerableProp: true }
    myEnumerableProp: true
    <prototype>: Object {  }

Beachten Sie, dass Arrays und Objekte nicht austauschbar verwendet werden können. Sie können nicht ein Objekt in ein Array oder ein Array in ein Objekt zu verteilen.

Anbieter für Ruhezeiten

Der Operator selbst hat dieselbe Syntax, der Restoperator (...) und führt je nach Kontext, in dem sie verwendet wird, die entgegengesetzte Funktion aus. Anstelle von Erweiterung einer iterierbaren Datenstruktur in einzelne Elemente, wie in desstrukturierenden Auftrags oder als Funktionsparameter, kombiniert der Operator „rest“ in eine iterierbare Datenstruktur umwandeln. Der Name leitet sich von der Tatsache ab, um „die übrigen Elemente“ einer Reihe von Datenwerten.

Bei Verwendung mit destruktiver Zuweisung wird die Syntax als „rest-Property“ bezeichnet. Syntax.

const myArray = [ "First", "Second", "Third", "Fourth", "Fifth" ];

[ myFirstElement, mySecondElement, ...remainingElements ] = myArray;

myFirstElement;
> "First"

mySecondElement;
> "Second"

remainingElements;
> Array(3) [ "Third", "Fourth", "Fifth"]

Wird verwendet, um eine unbestimmte Anzahl von Argumenten für eine Funktion bereitzustellen, heißt die Syntax „rest parameter“ Syntax:

function myFunction( ...myParameters ) {
    let result = 0;
    myParameters.forEach( ( myParam ) => {
        result += myParam;
    });
    return result;
};

myFunction( 2, 2 );
> 4

myFunction( 1, 1, 1, 10, 5 );
> 18

myFunction( 10, 11, 25 );
> 46

%TypedArray%

Typierte Arrays sind eine ES6-Funktion zum Speichern strukturierter Binärdaten, wenn Sie mit hochgeladenen Dateien oder WebGL

Wie bei Symbols wird auch das %TypedArray% intrinsische Funktion (normalerweise als %TypedArray% oder @@TypedArray dokumentiert) also nicht mit einer globalen Eigenschaft verwechselt werden kann) ist keine Konstruktorfunktion in dem herkömmlichen Sinn, und Sie können sie weder mit new aufrufen noch direkt aufrufen. Stattdessen bezieht sich %TypedArray% auf eine übergeordnete Klasse von Einzelpersonen. -Konstruktoren, die jeweils mit einem bestimmten Binärdatenformat arbeiten. Die Die intrinsische %TypedArray%-Klasse bietet Attribute und Dienstprogrammmethoden, die übernehmen alle abgeleiteten %TypedArray%-Konstruktorklassen und ihre Instanzen.

Wissen testen

Angegeben: "const myArray = [ 30, 50, 70 ];" was bewirkt "myArray[1]" zurück?

70
50
30

Wenn „myArray“ drei Werte hat, was gibt „myArray[9]“ zurück?

9
Null
Fehlermeldung
Undefined