W3cubDocs

/Web APIs

AmbientLightSensor

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 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.

EventTarget Sensor AmbientLightSensor

Constructor

AmbientLightSensor() Experimental

Creates a new AmbientLightSensor object.

Instance properties

AmbientLightSensor.illuminance Read only Experimental

Returns the current light level in lux of the ambient light level around the hosting device.

Instance methods

AmbientLightSensor doesn't have own methods. However, it inherits methods from its parent interfaces, Sensor and EventTarget.

Events

AmbientLightSensor doesn't have own events. However, it inherits events from its parent interface, Sensor.

Example

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();
}

Specifications

Browser compatibility

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