Get to know MDN better
Cette page a été traduite à partir de l'anglais par la communauté. Vous pouvez contribuer en rejoignant la communauté francophone sur MDN Web Docs.
Cette fonctionnalité est bien établie et fonctionne sur de nombreux appareils et versions de navigateurs. Elle est disponible sur tous les navigateurs depuis juillet 2015.
Un objet TypedArray décrit une vue organisée à la façon d'un tableau pour manipuler un tampon (buffer) de données binaires. TypedArray n'est pas une propriété globale, il n'existe pas non plus de constructeur TypedArray. En revanche, plusieurs propriétés globales existent et leurs valeurs permettent de construire des tableaux typés (typed arrays) avec différents types de données. Ceux-ci sont listés ci-après. Les pages suivantes permettent de décrire les propriétés et méthodes qui peuvent être utilisées sur les différents tableaux typés.
ECMAScript 2015 (ES6) définit un constructeur %TypedArray% qui est un [[Prototype]] de tous les constructeurs TypedArray. Ce constructeur n'est pas accessible directement. Il n'existe pas de %TypedArray% global ou de propriété TypedArray. Il est uniquement accessible via Object.getPrototypeOf(Int8Array.prototype) ou avec les méthodes semblables. L'ensemble des différents constructeurs TypedArrays hérite de propriétés communes de la fonction %TypedArray%. De plus, tous les prototypes des tableaux typés (TypedArray.prototype) ont %TypedArray%.prototype pour [[Prototype]].
Lorsqu'on crée une instance de TypedArray (par exemple, une instance de Int8Array ou autre), un tampon de mémoire tableau est créé en interne par le moteur (si un objet ArrayBuffer est passé en argument, c'est celui-ci qui est utilisé). C'est l'adresse de cette mémoire tampon qui est sauvegardée comme une propriété interne à l'objet. Toutes les méthodes de %TypedArray%.prototype utiliseront ensuite cet espace pour les opérations.
| Int8Array | -128 à 127 | 1 | Entier sur 8 bits signé en complément à deux | byte | int8_t |
| Uint8Array | 0 à 255 | 1 | Entier non-signé sur 8 bits | octet | uint8_t |
| Uint8ClampedArray | 0 à 255 | 1 | Entier non-signé sur 8 bits (écrété) | octet | uint8_t |
| Int16Array | -32768 à 32767 | 2 | Entier sur 16 bits, signé en complément à deux | short | int16_t |
| Uint16Array | 0 à 65535 | 2 | Entier non-signé sur 16 bits | unsigned short | uint16_t |
| Int32Array | -2147483648 à 2147483647 | 4 | Entier sur 32 bits, signé en complément à deux | long | int32_t |
| Uint32Array | 0 à 4294967295 | 4 | Entier sur 32 bits non-signé | unsigned long | uint32_t |
| Float32Array | -3.4E38 à 3.4E38 avec 1.2E-38 le plus petit nombre positif | 4 | Nombre flottant sur 32 bits au format IEEE avec 7 chiffres significatifs (par exemple 1.234567) | unrestricted float | float |
| Float64Array | -1.8E308 à 1.8E308 avec 5E-324 le plus petit nombre positif | 8 | Nombre flottant sur 64 bits au format IEEE avec 16 chiffres significatifs (par exemple 1.23456789012345) | unrestricted double | double |
| BigInt64Array | -2^63 à 2^63 - 1 | 8 | Entier sur 64 bits, signé en complément à deux integer | bigint | int64_t (signed long long) |
| BigUint64Array | 0 à 2^64 - 1 | 8 | Entier sur 64 bits non-signé | bigint | uint64_t (unsigned long long) |
Cet objet ne peut pas être instancié directement. On créera plutôt une instance d'un tableau typé d'un type donné, tel que Int8Array ou BigInt64Array. Ces différents types partagent une syntaxe commune pour leur constructeur :
Où TypedArray est un constructeur donné pour un type de tableau typé existant.
Lorsque le constructeur est appelé avec un argument longueur, un tampon de mémoire interne sous forme de tableau est créé et dont la taille est longueur multipliée par BYTES_PER_ELEMENT octets. Chaque élément du tableau contient des zéros.
tableauTypeLorsque le constructeur est appelé avec un argument tableauType, tableauType est copié dans un nouveau tableau typé. Pour un tableay typé dont le type n'est pas BigInt64Array, le paramètre peut être un objet de n'importe quel type de tableau typé en dehors de BigInt64Array (par exemple Int32Array). L'inverse est aussi valable, pour obtenir un tableau typé BigInt64Array, le paramètre devra nécessairement être de type BigInt64Array. Chaque valeur contenue dans tableauType est convertie dans le type correspondant au constructeur avant d'être copiée dans le nouveau tableau. La longueur du nouveau tableau typé sera la même que celle de l'argument tableauType.
objetLorsque le constructeur est appelé avec un objet comme argument, un nouveau tableau typé est créé à la façon de la méthode TypedArray.from().
buffer, decalageOctet, longueurLorsque le constructeur est appelé avec un tampon de mémoire buffer, et éventuellement des arguments decalageOctet et longueur, une nouvelle vue sous la formule d'un tableau typé est créé sur l'objet ArrayBuffer porté par le premier argument. Les paramètres decalageOctet et longueur indique l'intervalle de mémoire exposée à la vue du tableau typé. Si les deux paramètres sont absents, c'est tout le tampon qui est vu. Si seul le paramètre longueur est absent, c'est le reste du tampon qui est vu (à partir de decalageOctet).
Renvoie un nombre indiquant la taille, exprimée en octets, de chaque élément du tableau typé.
TypedArray.nameRenvoie la chaîne de caractères correspondant au nom du constructeur (par exemple, "Int8Array").
get TypedArray[@@species]La fonction de construction utilisée pour créer des objets dérivés.
TypedArrayLe prototype pour les objes TypedArray.
Crée un nouveau tableau typé à partir d'un objet itérable ou semblable à un tableau. Voir aussi Array.from().
TypedArray.of()Crée un nouveau tableau typé avec un nombre variable d'arguments. Voir aussi Array.of().
Renvoie l'objet ArrayBuffer référencé par le tableau typé. Il est déterminé au moment de la construction et est donc uniquement accessible en lecture seule.
TypedArray.prototype.byteLengthRenvoie la longueur, exprimée en octets, du tableau typé. Elle est déterminée au moment de la construction et est donc uniquement accessible en lecture seule.
TypedArray.prototype.byteOffsetRenvoie le décalage, exprimé en octet, de la vue fournie par le tableau typé par rapport au début de l'objet ArrayBuffer correspondant. Il est déterminé au moment de la construction et est donc uniquement accessible en lecture seule.
TypedArray.prototype.lengthRenvoie le nombre d'éléments contenus dans le tableau typé. Il est déterminé au moment de la construction et est donc uniquement accessible en lecture seule.
Prend une valeur entière comme argument et renvoie l'élément situé à cet indice. Il est possible d'utiliser des indices négatifs, le tableau est alors parcouru depuis la fin.
TypedArray.prototype.copyWithin()Copie une suite d'éléments de tableau dans le tableau typé. Voir aussi Array.prototype.copyWithin().
TypedArray.prototype.entries()Renvoie un nouvel objet itérateur de tableau qui contient les paires de clé/valeur pour chaque indice du tableau. Voir aussi Array.prototype.entries().
TypedArray.prototype.every()Teste si l'ensemble des éléments du tableau valident le test fourni par la fonction passée en argument. Voir aussi Array.prototype.every().
TypedArray.prototype.fill()Remplit l'ensemble des éléments du tableau situés entre un indice de début et un indice de fin avec une valeur statique. Voir aussi Array.prototype.fill().
TypedArray.prototype.filter()Crée un nouveau tableau avec l'ensemble des éléments du tableau pour lesquels la fonction passée en argument renvoi true. Voir aussi Array.prototype.filter().
TypedArray.prototype.find()Renvoie la valeur trouvée dans le tableau si un élément du tableau satisfait au critère fourni par la fonction passée en argument, ou undefined s'il n'existe pas de tel élément. Voir aussi Array.prototype.find().
TypedArray.prototype.findIndex()Renvoie l'indice d'un élément du tableau qui satisfait au critère fourni par la fonction passée en argument ou -1 s'il n'existe pas de tel élément. Voir aussi Array.prototype.findIndex().
TypedArray.prototype.forEach()Appelle une fonction pour chaque élément du tableau. Voir aussi Array.prototype.forEach().
TypedArray.prototype.includes()Détermine si un tableau typé inclut un certain élément, renvoyant true ou false selon le cas de figure. Voir aussi Array.prototype.includes().
TypedArray.prototype.indexOf()Renvoie le plus petit indice d'un élément du tableau qui est égal à la valeur fournie en argument, ou -1 si aucun élément n'est trouvé. Voir aussi Array.prototype.indexOf().
TypedArray.prototype.join()Fusionne l'ensemble des éléments du tableau en une chaîne de caractères. Voir aussi Array.prototype.join().
TypedArray.prototype.keys()Renvoie un nouvel itérateur de tableau qui contient les clés pour chaque indice du tableau. Voir aussi Array.prototype.keys().
TypedArray.prototype.lastIndexOf()Renvoie le plus grand indice d'un élément du tableau qui est égal à la valeur fournie, ou -1 s'il n'y a pas de tel élément. Voir aussi Array.prototype.lastIndexOf().
TypedArray.prototype.map()Crée un nouveau tableau dont les éléments sont les résultats de l'appel de la fonction passée en argument pour chaque élément du tableau original. Voir aussi Array.prototype.map().
TypedArray.prototype.reduce()Applique une fonction avec un accumulateur pour chaque valeur du tableau (de gauche à droite), afin de le réduire à une seule valeur. Voir aussi Array.prototype.reduce().
TypedArray.prototype.reduceRight()Applique une fonction avec un accumulateur pour chaque valeur du tableau (de droite à gauche), afin de le réduire à une seule valeur. Voir aussi Array.prototype.reduceRight().
TypedArray.prototype.reverse()Inverse l'ordre des éléments d'un tableau (le premier devenant le dernier, le dernier devenant le premier et ainsi de suite). Voir aussi Array.prototype.reverse().
TypedArray.prototype.set()Enregistre plusieurs valeurs dans le tableau typé à partir d'un tableau de valeurs donné.
TypedArray.prototype.slice()Extrait une section d'un tableau et renvoie un nouveau tableau. Voir aussi Array.prototype.slice().
TypedArray.prototype.some()Renvoie true si au moins un des éléments du tableau satisfait au critère fourni par la fonction passée en argument. Voir aussi Array.prototype.some().
TypedArray.prototype.sort()Trie les éléments du tableau à même le tableau puis le renvoie. Voir aussi Array.prototype.sort().
TypedArray.prototype.subarray()Renvoie un nouveau tableau typé avec les éléments contenus entre un indice de début et un indice de fin.
TypedArray.prototype.values()Renvoie un nouvel objet itérateur de tableau qui contient les valeurs pour chaque indice du tableau. Voir aussi Array.prototype.values().
TypedArray.prototype.toLocaleString()Renvoie une chaîne de caractères localisée qui représente le tableau et ses éléments. Voir aussi Array.prototype.toLocaleString().
TypedArray.prototype.toString()Renvoie une chaîne de caractères représentant le tableau et ses éléments. Voir aussi Array.prototype.toString().
TypedArray.prototype[@@iterator]()Renvoie un nouvel objet itérateur de tableau qui contient les valeurs pour chaque indice du tableau.
À partir d'ECMAScript 2015, les constructeurs TypedArray doivent être appelés avec l'opérateur new. Appeler un tel constructeur comme fonction, sans new, déclenchera une exception TypeError.
Il est possible d'accéder aux éléments du tableau en utilisant la notation usuelle avec les crochets. Cependant, définir ou accéder à des propriétés indexées ne se fera pas avec la chaîne de prototypes, même si l'indice utilisé est en dehors des limites du tableau. Les propriétés indexées seront uniquement basées sur le contenu du ArrayBuffer et ne consulteront pas les propriétés des objets. En revanche, il est toujours possible d'utiliser des propriétés nommées, comme avec les autres objets.
Les tableaux typés qui ne sont pas vides ne peuvent pas être gelés, car le tampon de mémoire ArrayBuffer sous-jacent pourrait être modifié via une autre vue fournie par un autre tableau typé sur ce même tampon. En pratique, cela voudrait dire que l'objet n'est pas réellement gelé.
Lors de la construction d'un objet TypedArray comme une vue sur un tampon ArrayBuffer, l'argument decalageOctet doit être aligné par rapport à la taille des éléments. Autrement dit, le décalage fourni doit être un multiple de BYTES_PER_ELEMENT.
À l'instar du paramètre decalageOctet, la propriété byteLength d'un objet ArrayBuffer passé au constructeur TypedArray doit être un multiple de la valeur BYTES_PER_ELEMENT correspondant au type du constructeur.
| ECMAScript® 2027 Language Specification # sec-typedarray-objects |
Activez JavaScript pour afficher ce tableau de compatibilité des navigateurs.
Cette page a été modifiée le 26 mars 2025 par les contributeur·ice·s du MDN.
Votre modèle pour un internet meilleur.
Visitez la société mère à but non lucratif de Mozilla Corporation, la Fondation Mozilla.
Certaines parties de ce contenu sont protégées par le droit d'auteur ©1998—2026 des contributeurs individuels de mozilla.org. Contenu disponible sous une licence Creative Commons.