Secure context: This feature is available only in secure contexts (HTTPS), in some or all supporting browsers.
The onstatechange Event Handler of the MIDIAccess interface processes statechange events.
The event fires when a new MIDI port is added or when an existing port changes state.
MIDIAccess.onstatechange = function; MIDIAccess.addEventListener('statechange', function);
The Navigator.requestMIDIAccess() method returns a promise that resolves with a MIDIAccess object. When a port changes state, information about that port is printed to the console.
navigator.requestMIDIAccess() .then(function(access) { access.onstatechange = function(e) { console.log(e.port.name, e.port.manufacturer, e.port.state); }; });
| Specification | 
|---|
| Web MIDI API  # dom-midiaccess-onstatechange  | 
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | WebView Android | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | |
onstatechange | 
43  | 
79  | 
No  | 
No  | 
30  | 
No  | 
43  | 
43  | 
No  | 
30  | 
No  | 
4.0  | 
    © 2005–2021 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
    https://developer.mozilla.org/en-US/docs/Web/API/MIDIAccess/onstatechange