Web Serial API

Secure context: This feature is available only in secure contexts (HTTPS), in some or all supporting browsers.

Experimental: This is an experimental technology
Check the Browser compatibility table carefully before using this in production.

Note: This feature is available in Dedicated Web Workers.

The Web Serial API provides a way for websites to read from and write to serial devices. These devices may be connected via a serial port, or be USB or Bluetooth devices that emulate a serial port.

Concepts and Usage

The Web Serial API is one of a set of APIs that allow websites to communicate with peripherals connected to a user's computer. It provides the ability to connect to devices that are required by the operating system to communicate via the serial API, rather than USB which can be accessed via the WebUSB API, or input devices that can be accessed via WebHID API.

Examples of serial devices include 3D printers, and microcontrollers such as the BBC micro:bit board.


Serial Experimental

Provides attributes and methods for finding and connecting to serial ports from a web page.

SerialPort Experimental

Provides access to a serial port on the host device.

Extensions to other interfaces

Returns a Serial object, which represents the entry point into the Web Serial API to enable the control of serial ports.

WorkerNavigator.serial Read only Experimental

Returns a Serial object, which represents the entry point into the Web Serial API to enable the control of serial ports.


The following examples demonstrate some of the functionality provided by the Web Serial API.

Checking for available ports

The following example shows how to check for available ports and allows the user to grant it permission to access additional ports.

The connect and disconnect events let sites react when a device is connected or disconnected from the system. The getPorts() method is then called to see connected ports that the site already has access to.

If the site doesn't have access to any connected ports it has to wait until it has user activation to proceed. In this example we use a click event handler on a button for this task. A filter is passed to requestPort() with a USB vendor ID in order to limit the set of devices shown to the user to only USB devices built by a particular manufacturer.

navigator.serial.addEventListener("connect", (e) => {
  // Connect to `e.target` or add it to a list of available ports.

navigator.serial.addEventListener("disconnect", (e) => {
  // Remove `e.target` from the list of available ports.

navigator.serial.getPorts().then((ports) => {
  // Initialize the list of available ports with `ports` on page load.

button.addEventListener("click", () => {
  const usbVendorId = 0xabcd;
    .requestPort({ filters: [{ usbVendorId }] })
    .then((port) => {
      // Connect to `port` or add it to the list of available ports.
    .catch((e) => {
      // The user didn't select a port.

Reading data from a port

The following example shows how to read data from a port. The outer loop handles non-fatal errors, creating a new reader until a fatal error is encountered and SerialPort.readable becomes null.

while (port.readable) {
  const reader = port.readable.getReader();
  try {
    while (true) {
      const { value, done } = await reader.read();
      if (done) {
        // |reader| has been canceled.
      // Do something with |value|...
  } catch (error) {
    // Handle |error|...
  } finally {


Web Serial API
# serial-interface

Browser compatibility

BCD tables only load in the browser

See also