Eslint参考手册
规则 | Rules
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 中引入的
- 规则资源
- 文档资源
规则 | Rules相关

ESLint 是一个代码规范和错误检查工具,有以下几个特性。所有东西都是可以插拔的。你可以调用任意的 rule api 或者 formatter api 去打包或者定义 rule or formatter。任意的 rule 都是独立的。没有特定的 coding style,你可以自己配置。
主页 | https://eslint.org/ |
源码 | https://github.com/eslint/eslint |
发布版本 | 4.12.0 |