Secure contextThis feature is available only in secure contexts (HTTPS), in some or all supporting browsers.
The XRInputSourceArray method forEach() executes the specified callback once for each input source in the array, starting at index 0 and progressing until the end of the list.
Syntax
xrInputSourceArray.forEach(callback, thisArg);
Parameters
callback- A function to execute once for each entry in the array
xrInputSourceArray. The callback accepts up to three parameters:
currentValue- A
XRInputSourceobject which is the value of the item from within thexrInputSourceArraywhich is currently being processed. currentIndexOptional- An integer value providing the index into the array at which the element given by
currentValueis located. If you don't need to know the index number, you can omit this. sourceListOptional- The
XRInputSourceArrayobject which is being processed. If you don't need this information, you may omit this.
thisArgOptional- The value to be used for
thiswhile executing the callback. Note that if you use arrow function notation (=>) to provide the callback, you can omitthisArg, since all arrow functions lexically bindthis.
Return value
Undefined.
Examples
This example snippet gets the list of inputs for a session and tries to handle each type of input device it supports using.
let inputSources = xrSession.inputSources;
inputSources.forEach((input) => {
if (input.gamepad) {
checkGamepad(input.gamepad);
} else {
if (input.targetRayMode === "tracked-pointer" &&
input.handedness === player.handedness) {
/* Handle main hand controller */
handleMainHandInput(input);
} else {
/* Handle other inputs */
}
}
});
For each input in the llist, the callback dispatches gamepad inputs to a checkGamepad() with the input's Gamepad object, taken from its gamepad property, as an input
For other devices, we look for tracked-pointer devices in the player's main hand, dispatching those to a handleMainHandInput() method.
Specifications
| Specification | Status | Comment |
|---|---|---|
| WebXR Device APIThe definition of 'XRInputSourceArray' in that specification.1 | Working Draft | XRInputSourceArray interface
|
[1] See [[../../../../MDN/Contribute/Howto/Write_an_API_reference/Information_contained_in_a_WebIDL_file#Iterator-like_methods|Iterator-like methods]] in [[../../../../MDN/Contribute/Howto/Write_an_API_reference/Information_contained_in_a_WebIDL_file|Information contained in a WebIDL file]] for information on how an iterable declaration in an interface definition causes entries(), forEach(), keys(), and values() methods to be exposed from objects that implement the interface.
Browser compatibility
Update compatibility data on GitHub
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
forEach()
|
Chrome
Full support 79 |
Edge
Full support 79 |
Firefox
No support No |
IE
No support No |
Opera
No support No |
Safari
No support No |
WebView Android
No support No |
Chrome Android
Full support 79 |
Firefox Android
No support No |
Opera Android
No support No |
Safari iOS
No support No |
Samsung Internet Android
Full support 11.2 |
Legend
- Full support
- Full support
- No support
- No support
See also
- Inputs and input sources
- The
ArraymethodforEach() XRInputSource
XRInputSourceArray.forEach() by Mozilla Contributors is licensed under CC-BY-SA 2.5.