BigInt是JavaScript中表示任意精度整数的原始类型,用于安全处理超安全整数范围(±(2^53−1))的大整数;字面量以n结尾,不支持小数或指数记法;不可与Number混算,需显式转换;支持+、-、、*、%及位运算,但不支持/(无小数结果)和>>>;适用于密码学、高精度时间戳、大型ID等场景。
BigInt 是 JavaScript 中专门用来表示任意精度整数的原始类型,它能安全地处理超出 Number 类型安全整数范围(-(2^53 - 1) 到 2^53 - 1)的大整数,不会丢失精度。
BigInt 的字面量写法和创建方式
声明 BigInt 最常用的方式是在整数字面量末尾加字母 n:
-
123n、0n、-456n都是合法的 BigInt 字面量 - 不能使用小数点或指数记法:
1.23n或1e3n会报语法错误 - 也可用
BigInt()构造函数转换:例如BigInt("9007199254740991999999"),但传入小数会抛出错误
BigInt 与 Number 不兼容
,不能混用运算
BigInt 和普通数字(Number)属于不同类型,JavaScript 不允许它们直接参与算术运算,否则会报 TypeError:
-
10n + 5❌ 报错:不能将 BigInt 与 number 混合运算 -
10n + 5n✅ 正确:两个 BigInt 可相加 - 如需交互,必须显式转换:
Number(100n)(仅当值在安全整数范围内)或BigInt(100)
支持的运算和限制
BigInt 支持大多数整数运算,但有明确边界:
- ✅ 支持:
+、-、*、**(幂)、%(取余)、位运算(&、|、^、、>>) - ❌ 不支持:
/(除法会向零截断,返回 BigInt,但不支持小数结果);>>>(无符号右移不支持) - 比较时注意:
10n === 10为false;但10n == 10为true(抽象相等会隐式转换,不推荐)
实际使用场景举例
常见于需要精确大整数计算的场合:
- 密码学运算(如 RSA 大素数模幂)
- 高精度时间戳(纳秒级,超过
Date.now() * 1000000的安全范围) - 处理大型数据库 ID(如 Twitter 的 Snowflake ID 超过 53 位)
- 金融系统中避免浮点误差的大额整数计数(注意:货币仍建议用字符串或专用库,BigInt 不处理小数)

,不能混用运算






