TypedArray
Baseline Widely available *
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
* Some parts of this feature may have varying levels of support.
Ein TypedArray Objekt beschreibt eine array-ähnliche Sicht auf einen
unterliegenden binären Datenpuffer.
Es gibt keine globale Eigenschaft namens TypedArray
, noch gibt es einen
direkt sichtbaren TypedArray
Konstruktor. Stattdessen gibt es eine Reihe von
unterschiedlichen globalen Eigenschaften, deren Werte typisierte Array-Konstruktoren für spezifische
Elementtypen sind, wie unten aufgeführt. Auf den folgenden Seiten finden Sie allgemeine Eigenschaften und
Methoden, die mit jedem typisierten Array verwendet werden können, das Elemente eines beliebigen Typs enthält.
Probieren Sie es aus
Beschreibung
Der TypedArray
Konstruktor (oft als %TypedArray%
bezeichnet, um seine "Intrinsicness" anzuzeigen, da er keinem in einem JavaScript-Programm exponierten globalen Element entspricht) dient als die gemeinsame Superklasse aller TypedArray
Subklassen. Denken Sie an %TypedArray%
als eine "abstrakte Klasse", die eine gemeinsame Schnittstelle von Dienstmethoden für alle typisierten Arraysubklassen bereitstellt. Dieser Konstruktor ist nicht direkt exponiert: Es gibt keine globale TypedArray
Eigenschaft. Er ist nur über Object.getPrototypeOf(Int8Array)
und ähnliche zugänglich.
Beim Erstellen einer Instanz einer TypedArray
Subklasse (z.B. Int8Array
) wird intern im Speicher ein Array-Puffer erstellt oder, wenn ein ArrayBuffer
Objekt als Konstruktionsargument angegeben wird, wird dieser ArrayBuffer
stattdessen verwendet. Die Pufferadresse wird als interne Eigenschaft der Instanz gespeichert, und alle Methoden von %TypedArray%.prototype
setzen und holen Werte basierend auf dieser Array-Pufferadresse.
TypedArray-Objekte
Typ | Wertebereich | Größe in Bytes | Web IDL Typ |
---|---|---|---|
Int8Array |
-128 bis 127 | 1 | byte |
Uint8Array |
0 bis 255 | 1 | octet |
Uint8ClampedArray |
0 bis 255 | 1 | octet |
Int16Array |
-32768 bis 32767 | 2 | short |
Uint16Array |
0 bis 65535 | 2 | unsigned short |
Int32Array |
-2147483648 bis 2147483647 | 4 | long |
Uint32Array |
0 bis 4294967295 | 4 | unsigned long |
Float16Array |
-65504 bis 65504 |
2 | N/A |
Float32Array |
-3.4e38 bis 3.4e38 |
4 | unrestricted float |
Float64Array |
-1.8e308 bis 1.8e308 |
8 | unrestricted double |
BigInt64Array |
-263 bis 263 - 1 | 8 | bigint |
BigUint64Array |
0 bis 264 - 1 | 8 | bigint |
Wertecodierung und Normalisierung
Alle typisierten Arrays arbeiten auf ArrayBuffer
s, bei denen Sie die genaue Byte-Darstellung jedes Elements sehen können. Wie die Zahlen im Binärformat codiert sind, ist daher von Bedeutung.
- Vorzeichenlose ganze Arrays (
Uint8Array
,Uint16Array
,Uint32Array
undBigUint64Array
) speichern die Zahl direkt im Binärformat. - Vorzeichenbehaftete ganze Arrays (
Int8Array
,Int16Array
,Int32Array
undBigInt64Array
) speichern die Zahl mit Zweierkomplement. - Gleitkomma-Arrays (
Float16Array
,Float32Array
undFloat64Array
) speichern die Zahl im IEEE 754 Gleitkommaformat. DieNumber
Referenz enthält mehr Informationen über das genaue Format. JavaScript-Zahlen verwenden standardmäßig das Double-Präzisions-Gleitkommaformat, das demFloat64Array
entspricht.Float32Array
verwendet 23 (statt 52) Bits für die Mantisse und 8 (statt 11) Bits für den Exponenten.Float16Array
verwendet 10 Bits für die Mantisse und 5 Bits für den Exponenten. Beachten Sie, dass die Spezifikation verlangt, dass alleNaN
Werte die gleiche Bit-Codierung verwenden, aber das genaue Bit-Muster ist implementierungsabhängig. Uint8ClampedArray
ist ein Sonderfall. Es speichert die Zahl im Binärformat wieUint8Array
, aber wenn man eine Zahl außerhalb des Bereichs speichert, klemmt es die Zahl auf den Bereich von 0 bis 255 durch mathematischen Wert, anstatt die höchstwertigen Bits abzuschneiden.
Alle typisierten Arrays außer Int8Array
, Uint8Array
und Uint8ClampedArray
speichern jedes Element mit mehreren Bytes. Diese Bytes können entweder von den höchstwertigen zu den niederwertigen geordnet sein (big-endian) oder von den niederwertigen zu den höchstwertigen (little-endian). Weitere Erklärungen finden Sie unter Endianness. Typisierte Arrays verwenden immer die native Byte-Reihenfolge der Plattform. Wenn Sie die Byte-Reihenfolge beim Schreiben und Lesen aus Puffs angeben möchten, sollten Sie stattdessen ein DataView
verwenden.
Beim Schreiben in diese typisierten Arrays werden Werte, die außerhalb des darstellbaren Bereichs liegen, normalisiert.
- Alle ganzen Arrays (außer
Uint8ClampedArray
) verwenden festbreite Zahllunmwandlung, die zuerst den Dezimalteil der Zahl abschneidet und dann die niedrigsten Bits berücksichtigt. Uint8ClampedArray
klemmt zuerst die Zahl auf den Bereich von 0 bis 255 (Werte größer als 255 werden zu 255 und Werte kleiner als 0 werden zu 0). Danach wird das Ergebnis gerundet (anstatt abgerundet) auf die nächste ganze Zahl, mit halbem zu ganzem; das bedeutet, wenn die Zahl genau zwischen zwei ganzen Zahlen liegt, wird sie auf die nächste gerade Zahl gerundet. Zum Beispiel wird0.5
zu0
,1.5
wird zu2
, und2.5
wird zu2
.Float16Array
undFloat32Array
führen ein "Runden zu ganzem" durch, um 64-Bit-Gleitkommazahlen in 32-Bit- und 16-Bit-Zahlen umzuwandeln. Dies ist der gleiche Algorithmus, denMath.fround()
undMath.f16round()
bereitstellen.
Verhalten bei der Ansicht eines größenveränderbaren Puffers
Wenn ein TypedArray
als Ansicht eines größenveränderbaren Puffers erstellt wird, hat das Verändern der Größe des unterliegenden Puffers unterschiedliche Auswirkungen auf die Größe des TypedArray
, je nachdem, ob das TypedArray
als längenverfolgend konstruiert wurde.
Wenn ein typisiertes Array ohne eine spezifische Größe durch Auslassen des dritten Parameters oder durch Übergeben von undefined
erstellt wird, wird das typisierte Array längenverfolgend und passt sich automatisch an den unterliegenden buffer
an, während dieser vergrößert wird:
const buffer = new ArrayBuffer(8, { maxByteLength: 16 });
const float32 = new Float32Array(buffer);
console.log(float32.byteLength); // 8
console.log(float32.length); // 2
buffer.resize(12);
console.log(float32.byteLength); // 12
console.log(float32.length); // 3
Wenn ein typisiertes Array mit einer spezifischen Größe unter Verwendung des dritten length
Parameters erstellt wird, wird es sich nicht an den buffer
anpassen, wenn dieser wächst:
const buffer = new ArrayBuffer(8, { maxByteLength: 16 });
const float32 = new Float32Array(buffer, 0, 2);
console.log(float32.byteLength); // 8
console.log(float32.length); // 2
console.log(float32[0]); // 0, the initial value
buffer.resize(12);
console.log(float32.byteLength); // 8
console.log(float32.length); // 2
console.log(float32[0]); // 0, the initial value
Wenn ein buffer
verkleinert wird, kann das betrachtete typisierte Array über die Grenzen hinausgehen, in diesem Fall wird die beobachtete Größe des typisierten Arrays auf 0 verkleinert. Dies ist der einzige Fall, in dem sich die Länge eines nicht längenverfolgenden typisierten Arrays ändern kann.
const buffer = new ArrayBuffer(8, { maxByteLength: 16 });
const float32 = new Float32Array(buffer, 0, 2);
buffer.resize(7);
console.log(float32.byteLength); // 0
console.log(float32.length); // 0
console.log(float32[0]); // undefined
Wenn Sie dann den buffer
erneut vergrößern, um das typisierte Array wieder in Grenzen zu bringen, wird die Größe des typisierten Arrays auf seinen ursprünglichen Wert zurückgesetzt.
buffer.resize(8);
console.log(float32.byteLength); // 8
console.log(float32.length); // 2
console.log(float32[0]); // 0 - back in bounds again!
Das Gleiche kann auch bei längenverfolgenden typisierten Arrays passieren, wenn der Puffer über den byteOffset
hinaus verkleinert wird.
const buffer = new ArrayBuffer(8, { maxByteLength: 16 });
const float32 = new Float32Array(buffer, 4);
// float32 is length-tracking, but it only extends from the 4th byte
// to the end of the buffer, so if the buffer is resized to be shorter
// than 4 bytes, the typed array will become out of bounds
buffer.resize(3);
console.log(float32.byteLength); // 0
Konstruktor
Dieses Objekt kann nicht direkt instanziiert werden – der Versuch, es mit new
zu konstruieren, wirft einen TypeError
.
new (Object.getPrototypeOf(Int8Array))();
// TypeError: Abstract class TypedArray not directly constructable
Stattdessen erstellen Sie eine Instanz eines typisierten Arrays eines bestimmten Typs, wie z.B. ein Int8Array
oder ein BigInt64Array
. Diese Objekte haben alle eine gemeinsame Syntax für ihre Konstruktoren:
new TypedArray()
new TypedArray(length)
new TypedArray(typedArray)
new TypedArray(object)
new TypedArray(buffer)
new TypedArray(buffer, byteOffset)
new TypedArray(buffer, byteOffset, length)
Wo TypedArray
ein Konstruktor für einen der konkreten Typen ist.
Parameter
typedArray
-
Wenn mit einer Instanz einer
TypedArray
Subklasse aufgerufen, wird dastypedArray
in ein neues typisiertes Array kopiert. Für einen nicht-bigintTypedArray
Konstruktor kann dertypedArray
Parameter nur einer der nicht-bigint Typen sein (wieInt32Array
). Ebenso kann für einen bigintTypedArray
Konstruktor (BigInt64Array
oderBigUint64Array
) dertypedArray
Parameter nur einer der bigint Typen sein. Jeder Wert intypedArray
wird in den entsprechenden Typ des Konstruktors umgewandelt, bevor er in das neue Array kopiert wird. Die Länge des neuen typisierten Arrays entspricht der Länge destypedArray
Arguments. object
-
Wenn mit einem Objekt aufgerufen, das keine
TypedArray
-Instanz ist, wird ein neues typisiertes Array auf die gleiche Weise erstellt wie mit derTypedArray.from()
Methode. length
Optional-
Wenn mit einem Nicht-Objekt aufgerufen, wird der Parameter als Zahl angesehen, welche die Länge des typisierten Arrays angibt. Ein interner Array-Puffer wird im Speicher erstellt, dessen Größe
length
multipliziert mitBYTES_PER_ELEMENT
Bytes ist und mit Nullen gefüllt wird. Das Weglassen aller Parameter ist äquivalent zur Verwendung von0
alslength
. buffer
,byteOffset
Optional,length
Optional-
Wenn mit einer
ArrayBuffer
oderSharedArrayBuffer
Instanz aufgerufen, optional mit einembyteOffset
und einemlength
Argument, wird eine neue typisierte Array-Ansicht erstellt, die den spezifizierten Puffer ansieht. DiebyteOffset
(in Bytes) undlength
(in Anzahl der Elemente, jeweilsBYTES_PER_ELEMENT
Bytes) Parameter spezifizieren den Speicherbereich, der durch die typisierte Array-Ansicht exponiert wird. Wenn beide weggelassen werden, wird der gesamtebuffer
betrachtet; wenn nurlength
weggelassen wird, wird der verbleibendebuffer
beginnend abbyteOffset
betrachtet. Wennlength
weggelassen wird, wird das typisierte Array längenverfolgend.
Ausnahmen
Alle TypeArray
Unterklasskonstruktoren funktionieren auf die gleiche Weise. Sie würden alle die folgenden Ausnahmen werfen:
TypeError
-
Wird in einem der folgenden Fälle geworfen:
- Ein
typedArray
wird übergeben, es ist jedoch ein bigint Typ, während der aktuelle Konstruktor kein solcher ist, oder umgekehrt. - Ein
typedArray
wird übergeben, aber der Puffer, den es betrachtet, ist getrennt, oder ein getrennterbuffer
wird direkt übergeben.
- Ein
RangeError
-
Wird in einem der folgenden Fälle geworfen:
- Die Länge des neuen typisierten Arrays ist zu groß.
- Die Länge des Puffers (wenn der
length
Parameter nicht spezifiziert ist) oderbyteOffset
ist kein ganzzahliges Vielfaches der Elementgröße des neuen typisierten Arrays. byteOffset
ist kein gültiger Array-Index (eine Ganzzahl zwischen 0 und 253 - 1).- Beim Erstellen einer Ansicht aus einem Puffer liegen die Grenzen außerhalb des Puffers. Mit anderen Worten,
byteOffset + length * TypedArray.BYTES_PER_ELEMENT > buffer.byteLength
.
Statische Eigenschaften
Diese Eigenschaften sind auf dem TypedArray
Konstruktorobjekt definiert und werden daher von allen TypedArray
Unterklasskonstruktoren geteilt.
TypedArray[Symbol.species]
-
Die Konstruktionsfunktion, die zum Erstellen abgeleiteter Objekte verwendet wird.
Alle TypedArray
Unterklassen haben auch die folgenden statischen Eigenschaften:
TypedArray.BYTES_PER_ELEMENT
-
Gibt einen Zahlenwert der Elementgröße für die verschiedenen
TypedArray
Objekte zurück.
Statische Methoden
Diese Methoden sind auf dem TypedArray
Konstruktorobjekt definiert und werden daher von allen TypedArray
Unterklasskonstruktoren geteilt.
TypedArray.from()
-
Erstellt ein neues
TypedArray
aus einem array-ähnlichen oder iterierbaren Objekt. Siehe auchArray.from()
. TypedArray.of()
-
Erstellt ein neues
TypedArray
mit einer variablen Anzahl von Argumenten. Siehe auchArray.of()
.
Instanzeigenschaften
Diese Eigenschaften sind auf TypedArray.prototype
definiert und werden von allen TypedArray
Unterklasseninstanzen geteilt.
TypedArray.prototype.buffer
-
Gibt den
ArrayBuffer
zurück, auf den das typisierte Array verweist. TypedArray.prototype.byteLength
-
Gibt die Länge (in Bytes) des typisierten Arrays zurück.
TypedArray.prototype.byteOffset
-
Gibt den Versatz (in Bytes) des typisierten Arrays vom Beginn seines
ArrayBuffer
zurück. TypedArray.prototype.constructor
-
Die Konstruktionsfunktion, die das Instanzobjekt erstellt hat.
TypedArray.prototype.constructor
ist die versteckteTypedArray
Konstruktionsfunktion, aber jede typisierte Arrayunterklasse definiert auch ihre eigeneconstructor
Eigenschaft. TypedArray.prototype.length
-
Gibt die Anzahl der im typisierten Array gehaltenen Elemente zurück.
TypedArray.prototype[Symbol.toStringTag]
-
Der anfängliche Wert der
TypedArray.prototype[Symbol.toStringTag]
Eigenschaft ist ein Getter, der denselben String wie der Name des typisierten Array-Konstruktors zurückgibt. Wenn der Wert vonthis
keine der typisierten Arrayunterklassen ist, wirdundefined
zurückgegeben. Diese Eigenschaft wird inObject.prototype.toString()
verwendet. DaTypedArray
jedoch seine eigenetoString()
Methode besitzt, wird diese Eigenschaft nicht verwendet, es sei denn, Sie rufenObject.prototype.toString.call()
mit einem Typisierten Array alsthisArg
auf.
Alle TypedArray
Unterklassen haben auch die folgenden Instanzeigenschaften:
TypedArray.prototype.BYTES_PER_ELEMENT
-
Gibt einen Zahlenwert der Elementgröße für die verschiedenen
TypedArray
Objekte zurück.
Instanzmethoden
Diese Methoden sind auf dem TypedArray
Prototypobjekt definiert und werden daher von allen TypedArray
Unterklasseninstanzen geteilt.
TypedArray.prototype.at()
-
Nimmt einen ganzzahligen Wert und gibt das Element an diesem Index zurück. Diese Methode erlaubt negative Ganzzahlen, die vom letzten Element zurückzählen.
TypedArray.prototype.copyWithin()
-
Kopiert eine Folge von Array-Elementen innerhalb des Arrays. Siehe auch
Array.prototype.copyWithin()
. TypedArray.prototype.entries()
-
Gibt ein neues Array Iterator Objekt zurück, das die Schlüssel/Wert-Paare für jeden Index im Array enthält. Siehe auch
Array.prototype.entries()
. TypedArray.prototype.every()
-
Überprüft, ob alle Elemente im Array den durch eine Funktion bereitgestellten Test bestehen. Siehe auch
Array.prototype.every()
. TypedArray.prototype.fill()
-
Füllt alle Elemente eines Arrays von einem Anfagsindex bis zu einem Endindex mit einem statischen Wert. Siehe auch
Array.prototype.fill()
. TypedArray.prototype.filter()
-
Erstellt ein neues Array mit allen Elementen dieses Arrays, für die die bereitgestellte Filterfunktion
true
zurückgibt. Siehe auchArray.prototype.filter()
. TypedArray.prototype.find()
-
Gibt das erste
Element
im Array zurück, das eine bereitgestellte Testfunktion erfüllt, oderundefined
, wenn kein geeignetes Element gefunden wird. Siehe auchArray.prototype.find()
. TypedArray.prototype.findIndex()
-
Gibt den ersten Indexwert im Array zurück, der ein Element hat, das eine bereitgestellte Testfunktion erfüllt, oder
-1
, wenn kein geeignetes Element gefunden wird. Siehe auchArray.prototype.findIndex()
. TypedArray.prototype.findLast()
-
Gibt den Wert des letzten Elements im Array zurück, das eine bereitgestellte Testfunktion erfüllt, oder
undefined
, wenn kein geeignetes Element gefunden wird. Siehe auchArray.prototype.findLast()
. TypedArray.prototype.findLastIndex()
-
Gibt den Index des letzten Elements im Array zurück, das eine bereitgestellte Testfunktion erfüllt, oder
-1
, wenn kein geeignetes Element gefunden wird. Siehe auchArray.prototype.findLastIndex()
. TypedArray.prototype.forEach()
-
Ruft eine Funktion für jedes Element im Array auf. Siehe auch
Array.prototype.forEach()
. TypedArray.prototype.includes()
-
Bestimmt, ob ein typisiertes Array ein bestimmtes Element enthält und gibt entsprechend
true
oderfalse
zurück. Siehe auchArray.prototype.includes()
. TypedArray.prototype.indexOf()
-
Gibt den ersten (kleinsten) Index eines Elements im Array zurück, das dem angegebenen Wert entspricht, oder
-1
, wenn keines gefunden wird. Siehe auchArray.prototype.indexOf()
. TypedArray.prototype.join()
-
Verbindet alle Elemente eines Arrays zu einem String. Siehe auch
Array.prototype.join()
. TypedArray.prototype.keys()
-
Gibt einen neuen Array-Iterator zurück, der die Schlüssel für jeden Index im Array enthält. Siehe auch
Array.prototype.keys()
. TypedArray.prototype.lastIndexOf()
-
Gibt den letzen (größten) Index eines Elements im Array zurück, das dem angegebenen Wert entspricht, oder
-1
, wenn keines gefunden wird. Siehe auchArray.prototype.lastIndexOf()
. TypedArray.prototype.map()
-
Erstellt ein neues Array mit den Ergebnissen des Aufrufens einer bereitgestellten Funktion auf jedes Element in diesem Array. Siehe auch
Array.prototype.map()
. TypedArray.prototype.reduce()
-
Wendet eine Funktion auf einen Akkumulator und jeden Wert des Arrays an (von links nach rechts), um es auf einen einzigen Wert zu reduzieren. Siehe auch
Array.prototype.reduce()
. TypedArray.prototype.reduceRight()
-
Wendet eine Funktion auf einen Akkumulator und jeden Wert des Arrays an (von rechts nach links), um es auf einen einzigen Wert zu reduzieren. Siehe auch
Array.prototype.reduceRight()
. TypedArray.prototype.reverse()
-
Kehrt die Reihenfolge der Elemente des Arrays um — das erste wird zum letzten und das letzte zum ersten. Siehe auch
Array.prototype.reverse()
. TypedArray.prototype.set()
-
Speichert mehrere Werte im typisierten Array und liest die Eingabewerte aus einem angegebenen Array.
TypedArray.prototype.slice()
-
Extrahiert einen Abschnitt eines Arrays und gibt ein neues Array zurück. Siehe auch
Array.prototype.slice()
. TypedArray.prototype.some()
-
Gibt
true
zurück, wenn mindestens ein Element in diesem Array die bereitgestellte Testfunktion erfüllt. Siehe auchArray.prototype.some()
. TypedArray.prototype.sort()
-
Sortiert die Elemente eines Arrays vor Ort und gibt das Array zurück. Siehe auch
Array.prototype.sort()
. TypedArray.prototype.subarray()
-
Gibt ein neues
TypedArray
aus dem angegebenen Start- und Endelementindex zurück. TypedArray.prototype.toLocaleString()
-
Gibt einen lokalisierten String zurück, der das Array und seine Elemente darstellt. Siehe auch
Array.prototype.toLocaleString()
. TypedArray.prototype.toReversed()
-
Gibt ein neues Array mit den Elementen in umgekehrter Reihenfolge zurück, ohne das ursprüngliche Array zu verändern.
TypedArray.prototype.toSorted()
-
Gibt ein neues Array mit den sortierten Elementen in aufsteigender Reihenfolge zurück, ohne das ursprüngliche Array zu verändern.
TypedArray.prototype.toString()
-
Gibt einen String zurück, der das Array und seine Elemente darstellt. Siehe auch
Array.prototype.toString()
. TypedArray.prototype.values()
-
Gibt ein neues Array Iterator Objekt zurück, das die Werte für jeden Index im Array enthält. Siehe auch
Array.prototype.values()
. TypedArray.prototype.with()
-
Gibt ein neues Array zurück, bei dem das Element am angegebenen Index durch den angegebenen Wert ersetzt wird, ohne das ursprüngliche Array zu verändern.
TypedArray.prototype[Symbol.iterator]()
-
Gibt ein neues Array Iterator Objekt zurück, das die Werte für jeden Index im Array enthält.
Beispiele
Eigenschaften-Zugriff
Sie können auf Elemente im Array mit standardmäßiger Array-Index-Syntax (das heißt, unter Verwendung der Klammernnotation) zugreifen. Das Abrufen oder Setzen von indizierten Eigenschaften in typisierten Arrays führt jedoch keine Suche in der Prototypkette nach dieser Eigenschaft durch, selbst wenn die Indizes außerhalb der Grenzen liegen. Indizierte Eigenschaften konsultieren den ArrayBuffer
und berücksichtigen nie Objekteigenschaften. Sie können dennoch benannte Eigenschaften verwenden, wie bei allen Objekten.
// Setting and getting using standard array syntax
const int16 = new Int16Array(2);
int16[0] = 42;
console.log(int16[0]); // 42
// Indexed properties on prototypes are not consulted (Fx 25)
Int8Array.prototype[20] = "foo";
new Int8Array(32)[20]; // 0
// even when out of bound
Int8Array.prototype[20] = "foo";
new Int8Array(8)[20]; // undefined
// or with negative integers
Int8Array.prototype[-1] = "foo";
new Int8Array(8)[-1]; // undefined
// Named properties are allowed, though (Fx 30)
Int8Array.prototype.foo = "bar";
new Int8Array(32).foo; // "bar"
Kann nicht eingefroren werden
TypedArray
s, die nicht leer sind, können nicht eingefroren werden, da ihre
unterliegenden ArrayBuffer
durch eine andere
TypedArray
Ansicht auf den Puffer geändert werden könnten. Dies würde bedeuten, dass das Objekt niemals wirklich eingefroren wäre.
const i8 = Int8Array.of(1, 2, 3);
Object.freeze(i8);
// TypeError: Cannot freeze array buffer views with elements
ByteOffset muss ausgerichtet sein
Beim Erstellen eines TypedArray
als Ansicht auf einem
ArrayBuffer
, muss das byteOffset
Argument an seine
Elementgröße ausgerichtet sein; mit anderen Worten, der Versatz muss ein Vielfaches von
BYTES_PER_ELEMENT
sein.
const i32 = new Int32Array(new ArrayBuffer(4), 1);
// RangeError: start offset of Int32Array should be a multiple of 4
const i32 = new Int32Array(new ArrayBuffer(4), 0);
ByteLength muss ausgerichtet sein
Analog zum byteOffset
-Parameter muss die byteLength
-Eigenschaft eines
ArrayBuffer
, der an den Konstruktor eines TypedArray
übergeben wird,
ein Vielfaches des BYTES_PER_ELEMENT
des Konstruktors sein.
const i32 = new Int32Array(new ArrayBuffer(3));
// RangeError: byte length of Int32Array should be a multiple of 4
const i32 = new Int32Array(new ArrayBuffer(4));
Spezifikationen
Specification |
---|
ECMAScript Language Specification # sec-typedarray-objects |
Browser-Kompatibilität
BCD tables only load in the browser
Siehe auch
- Polyfill von typisierten Arrays in
core-js
- JavaScript typisierte Arrays Leitfaden
ArrayBuffer
DataView
TextDecoder