HIDDevice
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
Secure context: This feature is available only insecure contexts (HTTPS), in some or allsupporting browsers.
Experimental:This is anexperimental technology
Check theBrowser compatibility table carefully before using this in production.
Note: This feature is available inWeb Workers, except forShared Web Workers.
TheHIDDevice interface of theWebHID API represents a HID Device. It provides properties for accessing information about the device, methods for opening and closing the connection, and the sending and receiving of reports.
In this article
Instance properties
This interface also inherits properties fromEventTarget.
HIDDevice.openedRead onlyExperimentalReturns a
boolean, true if the device has an open connection.HIDDevice.vendorIdRead onlyExperimentalReturns the vendorId of the HID device.
HIDDevice.productIdRead onlyExperimentalReturns the productId of the HID device.
HIDDevice.productNameRead onlyExperimentalReturns a string containing the product name of the HID device.
HIDDevice.collectionsRead onlyExperimentalReturns an array of report formats for the HID device.
Events
inputreportExperimentalFires when a report is sent from the device.
Instance methods
This interface also inherits methods fromEventTarget.
HIDDevice.open()ExperimentalOpens a connection to this HID device, and returns a
Promisewhich resolves once the connection has been successful.HIDDevice.close()ExperimentalCloses the connection to this HID device, and returns a
Promisewhich resolves once the connection has been closed.HIDDevice.forget()ExperimentalCloses the connection to this HID device and resets access permission, and returns a
Promisewhich resolves once the permission was reset.HIDDevice.sendReport()ExperimentalSends an output report to this HID Device, and returns a
Promisewhich resolves once the report has been sent.HIDDevice.sendFeatureReport()ExperimentalSends a feature report to this HID device, and returns a
Promisewhich resolves once the report has been sent.HIDDevice.receiveFeatureReport()ExperimentalReceives a feature report from this HID device in the form of a
Promisewhich resolves with aDataView. This allows typed access to the contents of this message.
Examples
The following example demonstrates listening for aninputreport event that will allow the application to detect which button is pressed on a Joy-Con Right device.
device.addEventListener("inputreport", (event) => { const { data, device, reportId } = event; // Handle only the Joy-Con Right device and a specific report ID. if (device.productId !== 0x2007 && reportId !== 0x3f) return; const value = data.getUint8(0); if (value === 0) return; const someButtons = { 1: "A", 2: "X", 4: "B", 8: "Y" }; console.log(`User pressed button ${someButtons[value]}.`);});In the following examplesendFeatureReport is used to make a device blink.
const reportId = 1;for (let i = 0; i < 10; i++) { // Turn off await device.sendFeatureReport(reportId, Uint32Array.from([0, 0])); await new Promise((resolve) => setTimeout(resolve, 100)); // Turn on await device.sendFeatureReport(reportId, Uint32Array.from([512, 0])); await new Promise((resolve) => setTimeout(resolve, 100));}You can see more examples, and live demos in the articleConnecting to uncommon HID devices.
Specifications
| Specification |
|---|
| WebHID API> # dom-hiddevice> |