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.
The Uint8Array typed array represents an array of 8-bit unsigned integers. The contents are initialized to 0 unless initialization data is explicitly provided. Once established, you can reference elements in the array using the object's methods, or using standard array index syntax (that is, using bracket notation).
Uint8Array is a subclass of the hidden TypedArray class.
Uint8Array is currently the only TypedArray subclass that has additional methods compared to other typed arrays. Because of its nature as a generic byte array, it is the most suitable for working with arbitrary binary data. It supports two sets of methods for the creation, serialization, and modification of Uint8Array data to/from hex strings and base64 strings.
Uint8Array.fromBase64(), Uint8Array.prototype.toBase64(), and Uint8Array.prototype.setFromBase64() for working with base64 strings, where 3 bytes are encoded by 4 characters that are either 0–9, A–Z, a–z, "+", and "/" (or "-" and "_", if using URL-safe base64).Uint8Array.fromHex(), Uint8Array.prototype.toHex(), and Uint8Array.prototype.setFromHex() for working with hex strings, where every byte is encoded by two characters, each one being either 0–9 or A–F (case-insensitive).Uint8Array()Creates a new Uint8Array object.
Also inherits static properties from its parent TypedArray.
Uint8Array.BYTES_PER_ELEMENTReturns a number value of the element size. 1 in the case of Uint8Array.
Inherits static methods from its parent TypedArray.
Uint8Array.fromBase64()Creates a new Uint8Array object from a base64-encoded string.
Uint8Array.fromHex()Creates a new Uint8Array object from a hex-encoded string.
Also inherits instance properties from its parent TypedArray.
These properties are defined on Uint8Array.prototype and shared by all Uint8Array instances.
Uint8Array.prototype.BYTES_PER_ELEMENTReturns a number value of the element size. 1 in the case of a Uint8Array.
Uint8Array.prototype.constructorThe constructor function that created the instance object. For Uint8Array instances, the initial value is the Uint8Array constructor.
Inherits instance methods from its parent TypedArray.
Uint8Array.prototype.setFromBase64()Populates this Uint8Array object with bytes from a base64-encoded string, returning an object indicating how many bytes were read and written.
Uint8Array.prototype.setFromHex()Populates this Uint8Array object with bytes from a hex-encoded string, returning an object indicating how many bytes were read and written.
Uint8Array.prototype.toBase64()Returns a base64-encoded string based on the data in this Uint8Array object.
Uint8Array.prototype.toHex()Returns a hex-encoded string based on the data in this Uint8Array object.
// From a length
const uint8 = new Uint8Array(2);
uint8[0] = 42;
console.log(uint8[0]); // 42
console.log(uint8.length); // 2
console.log(uint8.BYTES_PER_ELEMENT); // 1
// From an array
const x = new Uint8Array([21, 31]);
console.log(x[1]); // 31
// From another TypedArray
const y = new Uint8Array(x);
console.log(y[0]); // 21
// From an ArrayBuffer
const buffer = new ArrayBuffer(8);
const z = new Uint8Array(buffer, 1, 4);
console.log(z.byteOffset); // 1
// From an iterable
const iterable = (function* () {
yield* [1, 2, 3];
})();
const uint8FromIterable = new Uint8Array(iterable);
console.log(uint8FromIterable);
// Uint8Array [1, 2, 3]
| 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 | |
Uint8Array |
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 |
Uint8Array |
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 |
fromBase64 |
140 | 140 | 133 | 124 | 18.2 | 140 | 133 | 92 | 18.2 | No | 140 | 18.2 | 1.1.22 | 2.5.0 | 25.0.0 |
fromHex |
140 | 140 | 133 | 124 | 18.2 | 140 | 133 | 92 | 18.2 | No | 140 | 18.2 | 1.1.22 | 2.5.0 | 25.0.0 |
setFromBase64 |
140 | 140 | 133 | 124 | 18.2 | 140 | 133 | 92 | 18.2 | No | 140 | 18.2 | 1.1.22 | 2.5.0 | 25.0.0 |
setFromHex |
140 | 140 | 133 | 124 | 18.2 | 140 | 133 | 92 | 18.2 | No | 140 | 18.2 | 1.1.22 | 2.5.0 | 25.0.0 |
toBase64 |
140 | 140 | 133 | 124 | 18.2 | 140 | 133 | 92 | 18.2 | No | 140 | 18.2 | 1.1.22 | 2.5.0 | 25.0.0 |
toHex |
140 | 140 | 133 | 124 | 18.2 | 140 | 133 | 92 | 18.2 | No | 140 | 18.2 | 1.1.22 | 2.5.0 | 25.0.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/Uint8Array