在线文档教程
Eslint
规则 | Rules

prefer-numeric-literals

禁止parseInt()和Number.parseInt()支持二进制,八进制,和十六进制文字的(prefer-numeric-literals)

--fix命令行上的选项可以自动修复一些被这条规则反映的问题。

parseInt()Number.parseInt()功能可以用于打开的二进制,八进制,和十六进制字符串到整数。由于 ES6支持二进制,八进制和十六进制文字,因此该规则鼓励使用这些数字文字而不是parseInt()或者 Number.parseInt()

0b111110111 === 503; 0o767 === 503;

规则细节

此规则禁止调用parseInt()Number.parseInt()使用两个参数调用:一个字符串; 和2(二进制),8(八进制)或16(十六进制)的基数选项。

此规则的错误代码示例:

/*eslint prefer-numeric-literals: "error"*/ parseInt("111110111", 2) === 503; parseInt("767", 8) === 503; parseInt("1F7", 16) === 503; Number.parseInt("111110111", 2) === 503; Number.parseInt("767", 8) === 503; Number.parseInt("1F7", 16) === 503;

此规则的正确代码示例:

/*eslint prefer-numeric-literals: "error"*/ /*eslint-env es6*/ parseInt(1 parseInt(1, 3 Number.parseInt(1 Number.parseInt(1, 3 0b111110111 === 503; 0o767 === 503; 0x1F7 === 503; a[parseInt](1,2 parseInt(foo parseInt(foo, 2 Number.parseInt(foo Number.parseInt(foo, 2

何时不使用它

如果你想允许使用parseInt()Number.parseInt()二进制,八进制,或十六进制整数,或者如果你没有使用 ES6(因为二进制和八进制文字不是在 ES5及以下的支持),您可能希望禁用该规则。

兼容性

  • JSCS:requireNumericLiterals 版本此规则是在 ESLint 3.5.0.Resources 中引入的