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 Magnetometer interface of the Sensor APIs provides information about the magnetic field as detected by the device's primary magnetometer sensor.
To use this sensor, the user must grant permission to the 'magnetometer' device sensor through the Permissions API. In addition, this feature may be blocked by a Permissions Policy set on your server.
Magnetometer() Experimental
Creates a new Magnetometer object.
Magnetometer.x Read only Experimental
Returns a double containing the magnetic field around the device's x axis.
Magnetometer.y Read only Experimental
Returns a double containing the magnetic field around the device's y axis.
Magnetometer.z Read only Experimental
Returns a double containing the magnetic field around the device's z axis.
Magnetometer doesn't have own methods. However, it inherits methods from its parent interfaces, Sensor and EventTarget.
Magnetometer doesn't have own events. However, it inherits events from its parent interface, Sensor.
The magnetometer is typically read in the reading event callback. In the example below this occurs sixty times a second.
let magSensor = new Magnetometer({ frequency: 60 });
magSensor.addEventListener("reading", (e) => {
console.log(`Magnetic field along the X-axis ${magSensor.x}`);
console.log(`Magnetic field along the Y-axis ${magSensor.y}`);
console.log(`Magnetic field along the Z-axis ${magSensor.z}`);
});
magSensor.start();
| Specification |
|---|
| Magnetometer> # magnetometer-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 | |
Magnetometer |
56 | 79 | No | 43 | No | 56 | No | No | No | No | No | No |
Magnetometer |
56 | 79 | No | 43 | No | 56 | No | No | No | No | No | No |
x |
56 | 79 | No | 43 | No | 56 | No | No | No | No | No | No |
y |
56 | 79 | No | 43 | No | 56 | No | No | No | No | No | No |
z |
56 | 79 | No | 43 | No | 56 | 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/Magnetometer