版本

no-loss-of-precision

禁止使用在运行时转换为 JS Number 时会丢失精度的字面量数字

推荐

配置文件中使用来自 @eslint/jsrecommended 配置启用此规则

此规则将禁止使用在运行时转换为 JS Number 时由于 64 位浮点舍入而丢失精度的数字字面量。

规则详细信息

在 JS 中,Number 存储为双精度浮点数,根据IEEE 754 标准。因此,数字只能保留一定数量的位数的精度。如果程序员输入了额外的数字,这些数字将在转换为 Number 类型时丢失,并导致意外行为。

此规则的不正确代码示例

在游乐场中打开
/*eslint no-loss-of-precision: "error"*/

const a = 9007199254740993
const b = 5123000000000000000000000000001
const c = 1230000000000000000000000.0
const d = .1230000000000000000000000
const e = 0X20000000000001
const f = 0X2_000000000_0001;

此规则的正确代码示例

在游乐场中打开
/*eslint no-loss-of-precision: "error"*/

const a = 12345
const b = 123.456
const c = 123e34
const d = 12300000000000000000000000
const e = 0x1FFFFFFFFFFFFF
const f = 9007199254740991
const g = 9007_1992547409_91

版本

此规则在 ESLint v7.1.0 中引入。

资源

更改语言