This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
The buffer accessor property of TypedArray instances returns the ArrayBuffer or SharedArrayBuffer referenced by this typed array at construction time.
// Create an ArrayBuffer with a size in bytes const buffer = new ArrayBuffer(8); const uint16 = new Uint16Array(buffer); console.log(uint16.buffer.byteLength); // Expected output: 8
The buffer property is an accessor property whose set accessor function is undefined, meaning that you can only read this property. The value is established when the TypedArray is constructed and cannot be changed. TypedArray is one of the TypedArray objects.
Because a typed array is a view of a buffer, the underlying buffer may be longer than the typed array itself.
const buffer = new ArrayBuffer(8);
const uint16 = new Uint16Array(buffer);
uint16.buffer; // ArrayBuffer { byteLength: 8 }
const buffer = new ArrayBuffer(1024); const arr = new Uint8Array(buffer, 64, 128); console.log(arr.byteLength); // 128 console.log(arr.buffer.byteLength); // 1024 console.log(arr.buffer === buffer); // true
| Desktop | Mobile | Server | |||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | Bun | Deno | Node.js | |
buffer |
7 | 12 | 4 | 11.6 | 5.1 | 18 | 4 | 12 | 4.2 | 1.0 | 4 | 4.2 | 1.0.0 | 1.0 | 0.10.0 |
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/TypedArray/buffer