This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
The byteLength accessor property of ArrayBuffer instances returns the length (in bytes) of this array buffer.
// Create an ArrayBuffer with a size in bytes const buffer = new ArrayBuffer(8); // Use byteLength to check the size const bytes = buffer.byteLength; console.log(bytes); // Expected output: 8
The byteLength 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 array is constructed and cannot be changed. This property returns 0 if this ArrayBuffer has been detached.
const buffer = new ArrayBuffer(8); buffer.byteLength; // 8
| 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 | |
byteLength |
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/ArrayBuffer/byteLength