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 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.
The AmbientLightSensor interface of the Sensor APIs returns the current light level or illuminance of the ambient light around the hosting device.
To use this sensor, the user must grant permission to the 'ambient-light-sensor' device sensor through the Permissions API.
This feature may be blocked by a Permissions Policy set on your server.
AmbientLightSensor() Experimental
Creates a new AmbientLightSensor object.
AmbientLightSensor.illuminance Read only Experimental
Returns the current light level in lux of the ambient light level around the hosting device.
AmbientLightSensor doesn't have own methods. However, it inherits methods from its parent interfaces, Sensor and EventTarget.
AmbientLightSensor doesn't have own events. However, it inherits events from its parent interface, Sensor.
if ("AmbientLightSensor" in window) {
const sensor = new AmbientLightSensor();
sensor.addEventListener("reading", (event) => {
console.log("Current light level:", sensor.illuminance);
});
sensor.addEventListener("error", (event) => {
console.log(event.error.name, event.error.message);
});
sensor.start();
}
| Specification |
|---|
| Ambient Light Sensor> # ambient-light-sensor-interface> |
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | |
AmbientLightSensor |
6756 | 7979 | No | 5443 | No | 6756 | No | No | No | No | No | No |
AmbientLightSensor |
6756 | 7979 | No | 5443 | No | 6756 | No | No | No | No | No | No |
illuminance |
67In Chrome 79, this method stopped returning floats and returned integers to avoid fingerprinting.56In Chrome 79, this method stopped returning floats and returned integers to avoid fingerprinting. |
79In Edge 79, this method stopped returning floats and returned integers to avoid fingerprinting.79In Edge 79, this method stopped returning floats and returned integers to avoid fingerprinting. |
No |
54In Opera 66, this method stopped returning floats and returned integers to avoid fingerprinting.43In Opera 66, this method stopped returning floats and returned integers to avoid fingerprinting. |
No |
67In Chrome Android 79, this method stopped returning floats and returned integers to avoid fingerprinting.56In Chrome Android 79, this method stopped returning floats and returned integers to avoid fingerprinting. |
No | No | No | No | No | No |
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/AmbientLightSensor