BigInt 是 JavaScript 中用于安全处理任意精度整数的原始类型,适用于超大整数运算,需用 n 后缀或 BigInt() 创建,不支持小数、与 Number 混合运算,/ 运算向零截断,== 允许跨类型比较但 === 不允许,JSON 不支持需手动序列化。

JavaScript 中的 BigInt 是专门用于表示任意精度整数的原始类型,能安全处理超过 Number.MAX_SAFE_INTEGER(即 9007199254740991)的整数运算,避免精度丢失。它不是替代 Number,而是补充——只适用于整数,不支持小数、科学计数法或与 Number 混合运算(会报错)。
BigInt 的创建与基本用法
必须通过字面量加 n 后缀,或调用 BigInt() 构造函数生成:
const big1 = 1234567890123456789012345678901234567890n;-
const big2 = BigInt("9007199254740991000000000000000");(字符串入参可避免 Number 先转为不精确值) -
BigInt(100)合法,但BigInt(100.5)会抛出TypeError
运算规则与注意事项
BigInt 支持常见的算术运算符(+、-、*、**、%),但 / 运算结果会向零截断(不保留小数):
易通(企业网站管理系统)是一款小巧,高效,人性化的企业建站程序.易通企业网站程序是国内首款免费提供模板的企业网站系统.§ 简约的界面及小巧的体积:后台菜单完全可以修改成自己最需要最高效的形式;大部分操作都集中在下拉列表框中,以节省更多版面来显示更有价值的数据;数据的显示以Javascript数组类型来输出,减少数据的传输量,加快传输速度。 § 灵活的模板标签及模
-
10n / 3n === 3n(不是3.333...) - 不能与普通数字直接运算:
5n + 3报错;需显式转换:5n + BigInt(3)或Number(5n) + 3(仅当值在安全整数范围内) - 比较时,
==允许 BigInt 与 Number 交叉比较(如5n == 5为 true),但===严格不等(类型不同)
实际使用建议
适合场景包括:高精度 ID 处理(如 Twitter Snowflake)、密码学计算、大整数算法、金融系统中纯整数计数等。不推荐用于浮点需求或频繁跨类型交互的逻辑:
立即学习“Java免费学习笔记(深入)”;
- 后端传来的超长整数 ID,前端应作为字符串接收,再用
BigInt(str)处理,避免 JSON 自动转 Number 导致截断 - 避免在循环中反复构造 BigInt,可复用或提前定义常量
- 序列化时注意:JSON 不支持 BigInt,需手动转换(如转字符串)再解析
- 兼容性检查:现代浏览器和 Node.js 10.4+ 支持,旧环境需 Babel 插件或 polyfill(但 polyfill 无法完全模拟原生行为)
与 Number 和字符串的协作模式
三者常需配合使用:
- 输入:优先用字符串初始化 BigInt(
BigInt(idStr)),防止 Number 解析失真 - 输出:用
bigInt.toString()得到精确十进制字符串,供展示或传输 - 临时转换:仅当确认值 ≤
Number.MAX_SAFE_INTEGER时,才用Number(bigInt);否则应保持 BigInt 类型或转字符串








