files/en-us/web/api/rtcdatachannel/close/index.md
{{APIRef("WebRTC")}}
The RTCDataChannel.close() method closes the
{{domxref("RTCDataChannel")}}. Either peer is permitted to call this method to initiate
closure of the channel.
Closure of the data channel is not instantaneous. Most of the process of closing the connection is handled asynchronously; you can detect when the channel has finished closing by watching for a {{DOMxRef("RTCDataChannel.close_event", "close")}} event on the data channel.
The sequence of events which occurs in response to this method being called:
closing.close() returns to the caller.closed.RTCDataChannel is sent
an {{DOMxRef("RTCDataChannel.error_event", "error")}} event
with its {{DOMxRef("DOMException.name", "name")}} set to NetworkError.close()
None.
None ({{jsxref("undefined")}}).
const pc = new RTCPeerConnection();
const dc = pc.createDataChannel("my channel");
dc.onmessage = (event) => {
console.log(`received: ${event.data}`);
dc.close(); // We decided to close after the first received message
};
dc.onopen = () => {
console.log("datachannel open");
};
dc.onclose = () => {
console.log("datachannel close");
};
// Now negotiate the connection and so forth…
{{Specifications}}
{{Compat}}