JavaScript BigInt 是一种内置原始类型,用于表示任意精度整数,突破 Number 的安全整数限制(2⁵³−1);通过字面量(如123n)或 BigInt() 函数创建,支持基本算术运算但不与 Number 混用,适用于大ID、密码学等高精度场景。

JavaScript BigInt 是一种内置的原始数据类型,专门用于表示任意精度的整数,突破了传统 Number 类型的安全整数限制(2⁵³ − 1,即 9007199254740991)。当你需要精确处理远超这个范围的大整数(比如加密运算、高精度计时、大ID计算等),BigInt 就派上用场了。
BigInt 如何创建和表示大整数
BigInt 不是通过构造函数调用(如 new BigInt(123))创建的,而是使用字面量语法或 BigInt() 函数:
- 字面量:在整数末尾加
n,例如123n、0n、-999999999999999999999n - 函数转换:传入字符串或安全范围内的数字,如
BigInt("123456789012345678901234567890")或BigInt(123)(但BigInt(9007199254740992)会丢失精度,因为参数先被转为Number)
⚠️ 注意:不能用小数或科学计数法创建 BigInt,1.5n、1e10n 都会报语法错误。
BigInt 的运算和类型特性
BigInt 支持常见的算术运算(+、-、*、**、%),但不支持与 Number 类型混用(会直接报错,而非隐式转换):
立即学习“Java免费学习笔记(深入)”;
- ✅ 合法:
100n + 200n、5n ** 3n、100n % 7n - ❌ 报错:
100n + 5、10n === 10(值相等但类型不同,全等返回false) - ✅ 比较可跨类型:
100n > 99返回true;但==也不允许(100n == 100报错)
BigInt 的实际使用场景和限制
它适合需要整数精度的场景,比如:
- 处理数据库中超过
2⁵³的长整型 ID(如 Twitter 的 Snowflake ID) - 密码学中的大数模幂运算(需配合其他库,BigInt 本身提供基础运算)
- 金融系统中避免浮点误差的整数金额(以“分”为单位的大额计算)
但也有明显限制:
- 不能与
Math对象方法一起用(Math.pow(10n, 2)报错) - 不能用于
JSON.stringify()(会抛出 TypeError),需手动转换为字符串再序列化 - 不是
Number的子集,typeof 100n返回"bigint"
如何安全地在 Number 和 BigInt 之间转换
转换必须显式且谨慎:
- Number → BigInt:仅当原值是安全整数且无小数部分,推荐用字符串中介更稳妥:
BigInt(num.toString()) - BigInt → Number:用
Number(bigint),但超出2⁵³ − 1范围会丢失精度,建议仅用于小值或做范围校验 - 检查是否为 BigInt:
typeof value === 'bigint'
不复杂但容易忽略:只要涉及大整数,就该第一时间决定用 Number 还是 BigInt,并统一类型,避免运行时错误。










