Join the AI Workshop and learn to build real-world apps with AI. A hands-on, practical program to level up your skills.
JavaScript provides 8 Typed Array types:
Int8Array, an array of 8-bit signed integersInt16Array, an array of 16-bit signed integersInt32Array, an array of 32-bit signed integersUint8Array, an array of 8-bit unsigned integersUint16Array, an array of 16-bit unsigned integersUint32Array, an array of 32-bit unsigned integersFloat32Array, an array of 32-bit floating-point numbersFloat64Array, an array of 64-bit floating-point numbers
All of them are ArrayBufferView instances.
A Typed Array is essentially a view into an ArrayBuffer, where every item has the same size, and type.
DataViewis another view into an ArrayBuffer, but in this case the items in the array can have different sizes and types.
Here’s an example of how to create an array of 8-bit signed integers:
const a = new Int8Array()
You can pre-allocate n bytes:
const bytes = 1024
const a = new Int8Array(bytes)
The main use is to let you look into an ArrayBuffer, which on its own is opaque (we can’t inspect its content).
Here’s how we do so:
// we got this `buffer` ArrayBuffer
const a = new Int8Array(buffer)
Those typed arrays are array-like, so now we can inspect the content of the buffer via the usual array access techniques, and we have access to lots of methods and properties including map(), reduce() and so on.
The main use case for Typed Arrays is using them with WebGL, Web Audio, or the Canvas API. Many WebGL functions expect typed arrays, as they are much more performant than regular JavaScript arrays.
One thing to keep in mind is that typed arrays don’t let us control the endianness: it uses the byte order of the platform. In general this works out fine, because the main use case as we said is to use the array locally, using one of the multimedia APIs. Also, most consumer computers use little endian since Intel uses that convention. But, if you transfer the data of a Typed Array on a system that uses big endian, the data might be badly encoded and, as such, invalid.
In case you need this kind of control over endianness, use DataView instead.
Lessons in this unit:
| 0: | Introduction |
| 1: | ArrayBuffer |
| 2: | ArrayBufferView |
| 3: | ▶︎ Typed Arrays |
| 4: | DataView |
| 5: | Data URLs |