The DataView Object
Find out what is a DataView object and how to use it
DataView is a view into an ArrayBuffer, like Typed Arrays, but in this case the items in the array can have different sizes and types.
Here’s an example:
const buffer = new ArrayBuffer(64) const view = new DataView(buffer)
Since this is a view over a buffer, we can specify which byte we want to start from, and the length:
const view = new DataView(buffer, 10) //start at byte 10
const view = new DataView(buffer, 10, 30) //start at byte 10, and add 30 items
If we don’t add those additional arguments, the view starts at position 0 and loads all the bytes present in the buffer.
There is a set of methods we can use to add data into the buffer:
This is how to call one of those methods:
const buffer = new ArrayBuffer(64) const view = new DataView(buffer) view.setInt16(0, 2019)
By default data is stored using big endian notation. You can overwrite this setting and use little endian by adding a third parameter with the
const buffer = new ArrayBuffer(64) const view = new DataView(buffer) view.setInt16(0, 2019, true)
Here is how we can get data from the view:
const buffer = new ArrayBuffer(64) const view = new DataView(buffer) view.setInt16(0, 2019) view.getInt16(0) //2019
DataView is an
ArrayBufferView, we have those 3 read-only properties:
bufferpoints to the original ArrayBuffer
byteOffsetis the offset on that buffer
byteLengthis the length of its content in bytes
One thing to keep in mind is that typed arrays don’t let us control the endianness: it uses the endianness of the system. 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.
If you transfer the data of a Typed Array on another system, the data might be not badly encoded if it uses Big Endian and you use Little Endian.
In case you need this kind of control, DataView is a perfect choice.
THE VALLEY OF CODE
THE WEB DEVELOPER's MANUAL
You might be interested in those things I do:
- Learn to code in THE VALLEY OF CODE, your your web development manual
- Find a ton of Web Development projects to learn modern tech stacks in practice in THE VALLEY OF CODE PRO
- I wrote 16 books for beginner software developers, DOWNLOAD THEM NOW
- Every year I organize a hands-on cohort course coding BOOTCAMP to teach you how to build a complex, modern Web Application in practice (next edition February-March-April-May 2024)
- Learn how to start a solopreneur business on the Internet with SOLO LAB (next edition in 2024)
- Find me on X