Menu
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS DSA TYPESCRIPT ANGULAR ANGULARJS GIT POSTGRESQL MONGODB ASP AI R GO KOTLIN SWIFT SASS VUE GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE INTRO TO PROGRAMMING INTRO TO HTML & CSS BASH RUST

Basic JavaScript

JS Tutorial JS Syntax JS Variables JS Operators JS If Conditions JS Loops JS Strings JS Numbers JS Functions JS Objects JS Dates JS Arrays JS Typed Arrays JS Sets JS Maps JS Math JS RegExp JS Data Types JS Errors JS Events JS Programming JS References JS Versions

JS Advanced

JS Functions JS Objects JS Classes JS Iterations JS Asynchronous JS Modules JS Meta & Proxy JS Atomics JS HTML DOM JS Windows JS Web API JS AJAX JS JSON JS jQuery JS Graphics JS Examples JS Reference


JavaScript DataView

The DataView Object lets you read and write multiple numeric types in an ArrayBuffer, at any byte offset, with optional control over endianness (byte order).

What Is a DataView?

A DataView is a view on top of an ArrayBuffer.

A DataView does not store data by itself; instead, it lets you interpret the bytes in the buffer as different types:

  • 8-bit, 16-bit, 32-bit integers (signed and unsigned)
  • 32-bit and 64-bit floating point numbers
  • At arbitrary byte offsets in the buffer
  • With configurable little-endian or big-endian order

Use DataView when:

  • You have a binary format with fields of different types and sizes.
  • You need to control byte order (endianness).
  • Typed arrays like Uint8Array or Float32Array are not flexible enough.

Use DataView when you work with binary data where you need full control over byte layout and types (for example network packets, file formats, or interoperability with other languages).


Creating a DataView

To create a DataView, you need an ArrayBuffer.

Then you pass the ArrayBuffer to the new DataView() constructor:

Example

// Create a 16 bytes ArrayBuffer
const buffer = new ArrayBuffer(16);

// Create a new DataView
const view = new DataView(buffer);

// Get lengths and offset
let len1 = buffer.byteLength);
let len2 = view.byteLength;
let off1 = view.byteOffset;
Try it Yourself »

You can also create a DataView that starts at a specific offset and has a limited length:

Example

Starts at offset 4 with length 8:

// Create a 16 bytes ArrayBuffer
const buffer = new ArrayBuffer(16);

// Create a new DataView
const view = new DataView(buffer, 4, 8);

// Get lengths and offset
let len1 = buffer.byteLength);
let len2 = view.byteLength;
let off1 = view.byteOffset;
Try it Yourself »

Note

Multiple DataView and typed array views can share the same ArrayBuffer.


Reading and Writing DataView Values

DataView uses getXxx() and setXxx() methods to read and write values:

  • getInt8(), setInt8()
  • getUint16(), setUint16()
  • getInt32(), setInt32()
  • getFloat32(), setFloat32()
  • and more

Example

getInt32() and setInt32()

const buffer = new ArrayBuffer(8);
const view = new DataView(buffer);

// Write a 32-bit signed integer at byte offset 0
view.setInt32(0, 123456);

// Read it back
const value = view.getInt32(0);

console.log(value); // 123456

Example

getFloat64() and setFloat64()

const buffer = new ArrayBuffer(16);
const view = new DataView(buffer);

view.setFloat64(0, Math.PI);
view.setFloat64(8, Math.E);

const pi = view.getFloat64(0);
const e = view.getFloat64(8);

console.log("PI:", pi);
console.log("E:", e);
Note: The first argument is always the byte offset from the start of the underlying buffer (or the byteOffset of the view).

Endianness (Byte Order)

Many binary formats specify whether multi-byte numbers are stored as little-endian or big-endian.

  • Little-endian: Least significant byte first (most common on PCs).
  • Big-endian: Most significant byte first (common in some protocols).

Most DataView numeric methods have an optional littleEndian parameter:

  • true = little-endian
  • false (or omitted) = big-endian

Example: Writing with Little-Endian and Big-Endian

const buffer = new ArrayBuffer(4);
const view = new DataView(buffer);

// Same number, two different byte orders:
view.setUint32(0, 0x12345678, true); // little-endian

console.log(new Uint8Array(buffer));
// Example output: Uint8Array(4) [120, 86, 52, 18] (0x78, 0x56, 0x34, 0x12)

// Overwrite with big-endian
view.setUint32(0, 0x12345678, false); // big-endian

console.log(new Uint8Array(buffer));
// Example output: Uint8Array(4) [18, 52, 86, 120] (0x12, 0x34, 0x56, 0x78)
Tip: Always check the documentation for your file format or protocol to know which endianness to use.

Mixed Types in One Buffer

One of the main advantages of DataView is that you can mix different types in a single buffer. For example:

  • 1 byte for a flag
  • 2 bytes for a length
  • 4 bytes for a float

Example: Mixed Types

const buffer = new ArrayBuffer(12);
const view = new DataView(buffer);

// Byte 0: a flag (0 or 1)
view.setUint8(0, 1);

// Bytes 1-2: a 16-bit length (little-endian)
view.setUint16(1, 500, true);

// Bytes 4-11: a 64-bit float (skip byte 3 for alignment)
view.setFloat64(4, 3.14159, true);

// Read the values back
const flag = view.getUint8(0);
const length = view.getUint16(1, true);
const value = view.getFloat64(4, true);

console.log("Flag:", flag);
console.log("Length:", length);
console.log("Value:", value);

Summary

  • DataView is a flexible way to read and write multiple numeric types in an ArrayBuffer.
  • Use getXxx() and setXxx() methods with a byte offset (and optional endianness).
  • Great for binary protocols, file formats, and interoperability with other languages.
  • Combine DataView with typed arrays to inspect individual bytes easily.

Common Use Cases

  • Parsing binary file formats (images, audio, custom formats).
  • Implementing binary network protocols on top of WebSocket or WebRTC.
  • Interop with WebAssembly or native code where layout matters.
  • Re-implementing C/C++ style structs and unions in JavaScript.

DataView Reference

Revised December 2025

Constructor

Syntax Description
new DataView(buffer) View on entire ArrayBuffer.
new DataView(buffer, byteOffset) View starting at byteOffset to the end.
new DataView(buffer, byteOffset, byteLength) View of length byteLength starting at byteOffset.

Properties

Property Description
dataView.buffer The underlying ArrayBuffer.
dataView.byteLength Number of bytes in this view.
dataView.byteOffset Offset (in bytes) of this view from the start of the buffer.

Read Methods (get)

Method Description
getInt8(byteOffset) Reads an 8-bit signed integer.
getUint8(byteOffset) Reads an 8-bit unsigned integer.
getInt16(byteOffset, littleEndian?) Reads a 16-bit signed integer.
getUint16(byteOffset, littleEndian?) Reads a 16-bit unsigned integer.
getInt32(byteOffset, littleEndian?) Reads a 32-bit signed integer.
getUint32(byteOffset, littleEndian?) Reads a 32-bit unsigned integer.
getFloat32(byteOffset, littleEndian?) Reads a 32-bit floating point number.
getFloat64(byteOffset, littleEndian?) Reads a 64-bit floating point number.
getBigInt64(byteOffset, littleEndian?) Reads a 64-bit signed integer as BigInt.
getBigUint64(byteOffset, littleEndian?) Reads a 64-bit unsigned integer as BigInt.

Write Methods (set)

Method Description
setInt8(byteOffset, value) Writes an 8-bit signed integer.
setUint8(byteOffset, value) Writes an 8-bit unsigned integer.
setInt16(byteOffset, value, littleEndian?) Writes a 16-bit signed integer.
setUint16(byteOffset, value, littleEndian?) Writes a 16-bit unsigned integer.
setInt32(byteOffset, value, littleEndian?) Writes a 32-bit signed integer.
setUint32(byteOffset, value, littleEndian?) Writes a 32-bit unsigned integer.
setFloat32(byteOffset, value, littleEndian?) Writes a 32-bit floating point number.
setFloat64(byteOffset, value, littleEndian?) Writes a 64-bit floating point number.
setBigInt64(byteOffset, value, littleEndian?) Writes a 64-bit signed integer BigInt.
setBigUint64(byteOffset, value, littleEndian?) Writes a 64-bit unsigned integer BigInt.

×

Contact Sales

If you want to use W3Schools services as an educational institution, team or enterprise, send us an e-mail:
sales@w3schools.com

Report Error

If you want to report an error, or if you want to make a suggestion, send us an e-mail:
help@w3schools.com

W3Schools is optimized for learning and training. Examples might be simplified to improve reading and learning. Tutorials, references, and examples are constantly reviewed to avoid errors, but we cannot warrant full correctness of all content. While using W3Schools, you agree to have read and accepted our terms of use, cookies and privacy policy.

Copyright 1999-2025 by Refsnes Data. All Rights Reserved. W3Schools is Powered by W3.CSS.