The Math.log() static method returns the natural logarithm (base e) of a number. That is
Math.log()
Baseline Widely available
This feature is well established and works across many devices and browser versions. Itโs been available across browsers since July 2015.
Try it
function getBaseLog(x, y) {
return Math.log(y) / Math.log(x);
}
// 2 x 2 x 2 = 8
console.log(getBaseLog(2, 8));
// Expected output: 3
// 5 x 5 x 5 x 5 = 625
console.log(getBaseLog(5, 625));
// Expected output: 4
Syntax
Math.log(x)
Parameters
x-
A number greater than or equal to 0.
Return value
Description
Because log() is a static method of Math, you always use it as Math.log(), rather than as a method of a Math object you created (Math is not a constructor).
If you need the natural log of 2 or 10, use the constants Math.LN2 or Math.LN10. If you need a logarithm to base 2 or 10, use Math.log2() or Math.log10(). If you need a logarithm to other bases, use Math.log(x) / Math.log(otherBase) as in the example below; you might want to precalculate 1 / Math.log(otherBase) since multiplication in Math.log(x) * constant is much faster.
Beware that positive numbers very close to 1 can suffer from loss of precision and make its natural logarithm less accurate. In this case, you may want to use Math.log1p instead.
Examples
Using Math.log()
Math.log(-1); // NaN Math.log(-0); // -Infinity Math.log(0); // -Infinity Math.log(1); // 0 Math.log(10); // 2.302585092994046 Math.log(Infinity); // Infinity
Using Math.log() with a different base
The following function returns the logarithm of y with base x (i.e., ):
function getBaseLog(x, y) {
return Math.log(y) / Math.log(x);
}
If you run getBaseLog(10, 1000), it returns 2.9999999999999996 due to floating-point rounding, but still very close to the actual answer of 3.
Specifications
| Specification |
|---|
| ECMAScriptยฎ 2026 Language Specification # sec-math.log |
Browser compatibility
| Desktop | Mobile | Server | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | Deno | Node.js | |
log |
1 | 12 | 1 | 3 | 1 | 18 | 4 | 10.1 | 1 | 1.0 | 4.4 | 1.0 | 0.10.0 |
See also
© 2005–2024 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/log