Back to Content

NDEFReadingEvent: serialNumber property

files/en-us/web/api/ndefreadingevent/serialnumber/index.md

latest1.2 KB
Original Source

{{APIRef("Web NFC API")}}{{securecontext_header}}{{SeeCompatTable}}

The serialNumber property of the {{domxref("NDEFReadingEvent")}} interface returns the serial number of the device, which is used for anti-collision and identification, or an empty string if no serial number is available.

Value

A string containing the device's serial number.

Examples

This example shows how to create a convenience function that reads a single tag and then stops polling, saving battery life by cutting unneeded work. The example could easily be extended to time out after a given amount of milliseconds.

js
const ndefReader = new NDEFReader();

function read() {
  return new Promise((resolve, reject) => {
    const controller = new AbortController();
    controller.signal.onabort = reject;
    ndefReader.addEventListener(
      "reading",
      (event) => {
        controller.abort();
        resolve(event);
      },
      { once: true },
    );
    ndefReader.scan({ signal: controller.signal }).catch((err) => reject(err));
  });
}

read().then(({ serialNumber }) => {
  console.log(serialNumber);
});

Specifications

{{Specifications}}

Browser compatibility

{{Compat}}