RTCDataChannel: binaryType property
Baseline Widely available *
This feature is well established and works across many devices and browser versions. It’s been available across browsers since January 2020.
* Some parts of this feature may have varying levels of support.
The property binaryType
on the
RTCDataChannel
interface is a string which specifies
the type of object which should be used to represent binary data received
on the RTCDataChannel
. Values allowed by the
WebSocket.binaryType
property are also permitted here:
blob
if Blob
objects are being used or
arraybuffer
if ArrayBuffer
objects are being used. The
default is blob
.
When a binary message is received on the data channel, the resulting
message
event's MessageEvent.data
property is an object of
the type specified by the binaryType
.
Value
A string that can have one of these values:
"blob"
-
Received binary messages' contents will be contained in
Blob
objects. "arraybuffer"
-
Received binary messages' contents will be contained in
ArrayBuffer
objects.
Example
This code configures a data channel to receive binary data in
ArrayBuffer
objects, and establishes a listener for message
events which constructs a string representing the received data as a list of hexadecimal
byte values.
const dc = peerConnection.createDataChannel("Binary");
dc.binaryType = "arraybuffer";
dc.onmessage = (event) => {
const byteArray = new Uint8Array(event.data);
let hexString = "";
byteArray.forEach((byte) => {
hexString += `${byte.toString(16)} `;
});
};
Specifications
Specification |
---|
WebRTC: Real-Time Communication in Browsers # dom-datachannel-binarytype |
Browser compatibility
Report problems with this compatibility data on GitHubdesktop | mobile | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
binaryType | ||||||||||||
ArrayBuffer value | ||||||||||||
Blob value |
Legend
Tip: you can click/tap on a cell for more information.
- Full support
- Full support
- No support
- No support