BigInt 是 JavaScript 中用于精确表示任意精度整数的原始类型,解决 Number 类型超出 9007199254740991 后精度丢失问题;需用后缀 n 或 BigInt() 创建,不支持小数、Math 方法及 JSON 序列化,运算需同类型,ES2025 起支持。
BigInt 是 JavaScript 中用于表示任意精度整数的原始类型,专门解决 Number 类型无法精确表示超过 253 − 1(即 9007199254740991)的大整数的问题。
JavaScript 的 Number 类型基于 IEEE 754 双精度浮点数,能安全表示的最大整数是 Number.MAX_SAFE_INTEGER(9007199254740991)。超出这个范围后,整数会丢失精度:
9007199254740992 === 9007199254740993 返回 true(实际不相等,但 JS 无法区分)必须用字面量后加 n,或调用 BigInt() 构造函数(注意:不能传入小数):
const big1 = 123456789012345678901234567890n;const big2 = BigInt("123456789012345678901234567890");BigInt(100)
✅;BigInt(10.5) ❌(抛出 TypeError)支持常见算术运算:+、-、*、**、%,但不支持与 Number 混合运算(会报错),需显式转换:
10n + 20n ✅ → 30n
10n + 20 ❌ → TypeError10n + BigInt(20) 或 Number(10n) + 20(但后者可能溢出)它不是 Number 的升级替代品,而是补充,有明确边界:
Math 对象方法(如 Math.pow、Math.max),会报错== 或 ===?可以,但仅限 ===(严格相等)支持跨类型比较:10n === 10 是 false,10n == 10 是 true(不推荐用 ==)JSON.stringify(100n) 会抛错,需手动处理(如转字符串)"bigint",是独立的原始类型基本上就这些。BigInt 解决了大整数精度痛点,但要用对场景,注意类型隔离和兼容性(ES2025 起支持,现代浏览器和 Node.js 10.4+ 均可用)。