--- title: ArrayBuffer slug: Web/JavaScript/Reference/Global_Objects/ArrayBuffer tags: - ArrayBuffer - Constructor - JavaScript - Reference - TypedArrays translation_of: Web/JavaScript/Reference/Global_Objects/ArrayBuffer original_slug: Web/JavaScript/Reference/Objets_globaux/ArrayBuffer ---
L'objet ArrayBuffer
est utilisé afin de représenter un tampon (buffer) de données binaires de longueur fixe de façon générique. C'est un tableau d'octets. La manipulation du contenu d'un ArrayBuffer
se fait de façon indirecte en créant un tableau typé ou un objet {{jsxref("DataView")}} qui permet de représenter le tampon dans un format donné qui permet de lire/écrire des contenus dans le tampon de mémoire.
Le code source de cet exemple interactif est disponible dans un dépôt GitHub. Si vous souhaitez contribuez à ces exemples, n'hésitez pas à cloner https://github.com/mdn/interactive-examples et à envoyer une pull request !
new ArrayBuffer(longueur)
longueur
Un nouvel objet ArrayBuffer
de la taille donnée. Ses éléments sont initialisés à 0.
Une exception {{jsxref("RangeError")}} est levée lorsque l'argument longueur
est supérieur à {{jsxref("Number.MAX_SAFE_INTEGER")}} (soit 253) ou s'il est négatif.
Le constructeur ArrayBuffer
crée une nouvelle instance d'ArrayBuffer
dont la longueur est celle donnée lors de la construction.
ArrayBuffer.length
ArrayBuffer
. Elle vaut 1.ArrayBuffer
.true
si arg
est une des vues sur l'ArrayBuffer
telle qu'un tableau typé ou un objet {{jsxref("DataView")}}, sinon elle renvoie false
.ArrayBuffer
dont le contenu est transféré depuis les données de ancienTampon
et qui est ensuite tronqué ou rallongé avec des zéros pour que la taille du nouveau tampon soit nouvelleLongueur
.ArrayBuffer
Toutes les instances d'ArrayBuffer
héritent de {{jsxref("ArrayBuffer.prototype")}}.
{{page('fr/docs/Web/JavaScript/Reference/Objets_globaux/ArrayBuffer/prototype','Propri.C3.A9t.C3.A9s')}}
{{page('fr/docs/Web/JavaScript/Reference/Objets_globaux/ArrayBuffer/prototype','M.C3.A9thodes')}}
Dans cet exemple, on crée un tampon sur 8 octets avec une vue {{jsxref("Int32Array")}} qui fait référence à ce tampon :
var tampon = new ArrayBuffer(8); var vue = new Int32Array(tampon);
Spécification | État | Commentaires |
---|---|---|
{{SpecName('Typed Array')}} | {{Spec2('Typed Array')}} | Remplacée par ECMAScript 6. |
{{SpecName('ES6', '#sec-arraybuffer-constructor', 'ArrayBuffer')}} | {{Spec2('ES6')}} | Définition initiale au sein d'un standard ECMA. new est obligaoire pour utiliser le constructeur. |
{{SpecName('ESDraft', '#sec-arraybuffer-constructor', 'ArrayBuffer')}} | {{Spec2('ESDraft')}} |
{{Compat("javascript.builtins.ArrayBuffer")}}
À partir d'ECMAScript 2015 (ES6), ArrayBuffer
doit être utilisée avec {{jsxref("Opérateurs/L_opérateur_new", "new")}}. Appeler un constructeur ArrayBuffer
comme une fonction, sans new
, provoquera une exception {{jsxref("TypeError")}}.
var dv = ArrayBuffer(10); // TypeError: calling a builtin ArrayBuffer constructor // without new is forbidden
var dv = new ArrayBuffer(10);