RTCDataChannel
{{APIRef("WebRTC")}}
The RTCDataChannel interface represents a network channel which can be used for bidirectional peer-to-peer transfers of arbitrary data. Every data channel is associated with an {{DOMxRef("RTCPeerConnection")}} , and each peer connection can have up to a theoretical maximum of 65,534 data channels (the actual limit may vary from browser to browser).
To create a data channel and ask a remote peer to join you, call the {{DOMxRef("RTCPeerConnection")}} 's {{DOMxRef("RTCPeerConnection.createDataChannel", "createDataChannel()")}} method. The peer being invited to exchange data receives a {{DOMxRef("RTCPeerConnection.datachannel_event", "datachannel")}} event (which has type {{DOMxRef("RTCDataChannelEvent")}} ) to let it know the data channel has been added to the connection.
RTCDataChannel is a transferable object.
{{InheritanceDiagram}}
Instance properties
Also inherits properties from {{DOMxRef("EventTarget")}} .
{{DOMxRef("RTCDataChannel.binaryType", "binaryType")}}- : A string specifying the type of object
that should be used to represent binary data received on the
RTCDataChannel. Values are the same as allowed on the{{DOMxRef("WebSocket.binaryType")}}property:blobif{{DOMxRef("Blob")}}objects are being used, orarraybufferif{{jsxref("ArrayBuffer")}}objects are being used. The default isarraybuffer.
- : A string specifying the type of object
that should be used to represent binary data received on the
{{DOMxRef("RTCDataChannel.bufferedAmount", "bufferedAmount")}}{{ReadOnlyInline}}- : Returns the number of bytes of data currently queued to be sent over the data channel.
{{DOMxRef("RTCDataChannel.bufferedAmountLowThreshold", "bufferedAmountLowThreshold")}}- : Specifies the number of bytes of buffered outgoing data that is considered “low”. The default value is 0.
{{DOMxRef("RTCDataChannel.id", "id")}}{{ReadOnlyInline}}- : Returns an ID number (between 0 and 65,534)
which uniquely identifies the
RTCDataChannel.
- : Returns an ID number (between 0 and 65,534)
which uniquely identifies the
{{DOMxRef("RTCDataChannel.label", "label")}}{{ReadOnlyInline}}- : Returns a string that contains a name describing the data channel. These labels are not required to be unique.
{{DOMxRef("RTCDataChannel.maxPacketLifeTime", "maxPacketLifeTime")}}{{ReadOnlyInline}}- : Returns the amount of time,
in milliseconds,
the browser is allowed to take to attempt to transmit a message,
as set when the data channel was created,
or
null.
- : Returns the amount of time,
in milliseconds,
the browser is allowed to take to attempt to transmit a message,
as set when the data channel was created,
or
{{DOMxRef("RTCDataChannel.maxRetransmits", "maxRetransmits")}}{{ReadOnlyInline}}- : Returns the maximum number of times
the browser should try to retransmit a message before giving up,
as set when the data channel was created,
or
null, which indicates that there is no maximum.
- : Returns the maximum number of times
the browser should try to retransmit a message before giving up,
as set when the data channel was created,
or
{{DOMxRef("RTCDataChannel.negotiated", "negotiated")}}{{ReadOnlyInline}}- : Indicates
whether the
RTCDataChannel’s connection was negotiated by the Web app (true) or by the WebRTC layer (false). The default isfalse.
- : Indicates
whether the
{{DOMxRef("RTCDataChannel.ordered", "ordered")}}{{ReadOnlyInline}}- : Indicates whether or not the data channel guarantees in-order delivery of messages;
the default is
true, which indicates that the data channel is indeed ordered.
- : Indicates whether or not the data channel guarantees in-order delivery of messages;
the default is
{{DOMxRef("RTCDataChannel.protocol", "protocol")}}{{ReadOnlyInline}}- : Returns a string containing the name of the subprotocol in use.
If no protocol was specified
when the data channel was created,
then this property’s value is the empty string (
"").
- : Returns a string containing the name of the subprotocol in use.
If no protocol was specified
when the data channel was created,
then this property’s value is the empty string (
{{DOMxRef("RTCDataChannel.readyState", "readyState")}}{{ReadOnlyInline}}- : Returns a string
which indicates the state of the data channel’s underlying data connection.
It can have one of the following values:
connecting,open,closing, orclosed.
- : Returns a string
which indicates the state of the data channel’s underlying data connection.
It can have one of the following values:
Obsolete properties
{{DOMxRef("RTCDataChannel.reliable", "reliable")}}{{ReadOnlyInline}}{{Deprecated_Inline}}{{Non-standard_Inline}}- : Indicates whether or not the data channel is reliable.
Instance methods
Also inherits methods from {{DOMxRef("EventTarget")}} .
{{DOMxRef("RTCDataChannel.close", "close()")}}- : Closes the
RTCDataChannel. Either peer is permitted to call this method to initiate closure of the channel.
- : Closes the
{{DOMxRef("RTCDataChannel.send", "send()")}}- : Sends data across the data channel to the remote peer.
Events
{{domxref("RTCDataChannel.bufferedamountlow_event", "bufferedamountlow")}}- : Sent
when the number of bytes of data in the outgoing data buffer
falls below the value specified by
{{domxref("RTCDataChannel.bufferedAmountLowThreshold", "bufferedAmountLowThreshold")}}.
- : Sent
when the number of bytes of data in the outgoing data buffer
falls below the value specified by
{{domxref("RTCDataChannel.close_event", "close")}}- : Sent when the underlying data transport closes.
{{domxref("RTCDataChannel.closing_event", "closing")}}- : Sent when the underlying data transport is about to start closing.
{{domxref("RTCDataChannel.error_event", "error")}}- : Sent when an error occurs on the data channel.
{{domxref("RTCDataChannel.message_event", "message")}}- : Sent when a message has been received from the remote peer.
The message contents can be found
in the event’s
{{domxref("MessageEvent.data", "data")}}property.
- : Sent when a message has been received from the remote peer.
The message contents can be found
in the event’s
{{domxref("RTCDataChannel.open_event", "open")}}- : Sent when the data channel is first opened, or when an existing data channel’s underlying connection re-opens.
Data format
The underlying data format is defined by the IEEE specification SDP Offer/Answer Procedures for SCTP over DTLS Transport(RFC 8841). The current format specifies its protocol as either "UDP/DTLS/SCTP" (UDP carrying DTLS carrying SCTP) or "TCP/DTLS/SCTP" (TCP carrying DTLS carrying SCTP). Older browsers may only specify "DTLS/SCTP".
Example
const pc = new RTCPeerConnection();
const dc = pc.createDataChannel("my channel");
dc.onmessage = (event) => {
console.log(`received: ${event.data}`);
};
dc.onopen = () => {
console.log("datachannel open");
};
dc.onclose = () => {
console.log("datachannel close");
};
Specifications
{{Specifications}}
Browser compatibility
{{Compat}}