Disallow the use of Math.pow
in favor of the **
operator
Some problems reported by this rule are automatically fixable by the --fix
command line option
Introduced in ES2016, the infix exponentiation operator **
is an alternative for the standard Math.pow
function.
Infix notation is considered to be more readable and thus more preferable than the function notation.
This rule disallows calls to Math.pow
and suggests using the **
operator instead.
Examples of incorrect code for this rule:
/*eslint prefer-exponentiation-operator: "error"*/
const foo = Math.pow(2, 8);
const bar = Math.pow(a, b);
let baz = Math.pow(a + b, c + d);
let quux = Math.pow(-1, n);
Examples of correct code for this rule:
/*eslint prefer-exponentiation-operator: "error"*/
const foo = 2 ** 8;
const bar = a ** b;
let baz = (a + b) ** (c + d);
let quux = (-1) ** n;
This rule should not be used unless ES2016 is supported in your codebase.
This rule was introduced in ESLint v6.7.0.
© OpenJS Foundation and other contributors
Licensed under the MIT License.
https://eslint.org/docs/latest/rules/prefer-exponentiation-operator