noPrecisionLoss (since v1.0.0)
Diagnostic Category: lint/correctness/noPrecisionLoss
Sources:
- Same as:
no-loss-of-precision
- Same as:
@typescript-eslint/no-loss-of-precision
- Same as:
lossy_float_literal
Disallow literal numbers that lose precision
Examples
Section titled ExamplesInvalid
Section titled Invalidcorrectness/noPrecisionLoss.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
correctness/noPrecisionLoss.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
correctness/noPrecisionLoss.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
correctness/noPrecisionLoss.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