noPrecisionLoss
Diagnostic Category: lint/correctness/noPrecisionLoss
Since: v1.0.0
Sources:
- Same as:
no-loss-of-precision
- Same as:
@typescript-eslint/no-loss-of-precision
- Same as:
lossy_float_literal
Description
Section titled DescriptionDisallow literal numbers that lose precision
Examples
Section titled ExamplesInvalid
Section titled Invalidcode-block.js:1:11 lint/correctness/noPrecisionLoss ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ This number literal will lose precision at runtime.
> 1 │ const x = 9007199254740993
│ ^^^^^^^^^^^^^^^^
2 │
ℹ The value at runtime will be 9007199254740992
code-block.js:1:11 lint/correctness/noPrecisionLoss ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ This number literal will lose precision at runtime.
> 1 │ const x = 5.123000000000000000000000000001
│ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
2 │
ℹ The value at runtime will be 5.123
code-block.js:1:11 lint/correctness/noPrecisionLoss ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ This number literal will lose precision at runtime.
> 1 │ const x = 0x20000000000001
│ ^^^^^^^^^^^^^^^^
2 │
ℹ The value at runtime will be 9007199254740992
code-block.js:1:11 lint/correctness/noPrecisionLoss ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ This number literal will lose precision at runtime.
> 1 │ const x = 0x2_000000000_0001;
│ ^^^^^^^^^^^^^^^^^^
2 │
ℹ The value at runtime will be 9007199254740992