登录
首页 >  文章 >  前端

BigInt数字后缀使用指南

时间:2026-04-20 15:28:35 397浏览 收藏

JavaScript中的BigInt字面量必须严格以小写n结尾,仅支持十进制、二进制(0b)、八进制(0o)和十六进制(0x)整数形式,禁止小数点、科学计数法、大写N、前导零等常见误用;它与Number类型完全隔离,无法自动混合运算,需显式转换且存在精度风险,同时JSON原生不支持——掌握这些硬性规范,不仅能避免SyntaxError和TypeError,还能写出更安全、可维护的大整数处理代码。

JavaScript中BigInt字面量n后缀的编写语法规范

JavaScript中BigInt字面量必须以小写字母 n 作为后缀,且不能与浮点数、科学计数法或十六进制前缀(如 0x)混用;它只支持十进制、二进制(0b)、八进制(0o)和十六进制(0x)整数字面量加 n

合法的BigInt字面量写法

以下形式均符合语法规范:

  • 123n —— 十进制整数后直接加 n
  • 0b1101n —— 二进制,前缀 0b + 数字 + n
  • 0o755n —— 八进制,前缀 0o + 数字 + n
  • 0xFFn —— 十六进制,前缀 0x + 大小写混合字母/数字 + n

常见的非法写法及原因

这些写法会触发 SyntaxError

  • 123.45n —— 小数点不被允许,BigInt只表示整数
  • 1e10n —— 科学计数法不支持,即使结果是整数也不行
  • 0x12.3n —— 十六进制中不能含小数点
  • 123N123N —— 后缀必须是小写 n,大写 N 无效
  • 0123n —— 带前导零的十进制字面量在严格模式下报错(虽非BigInt专属,但需注意)

与Number类型转换的注意事项

BigInt不能自动与Number混用运算,也不能直接用于大多数内置函数(如 Math.max):

  • 加减乘除等算术操作符仅在两个操作数同为BigInt时有效,否则抛出 TypeError
  • 需显式转换:BigInt(123) 可将Number转为BigInt(但不能转小数),Number(123n) 可转回Number(但超出 2^53 - 1 范围会丢失精度)
  • JSON不支持BigInt,JSON.stringify(123n) 会抛错,需手动处理

实际编码建议

为保障可读性与兼容性,推荐:

  • 始终使用小写 n,避免大小写混淆
  • 对大整数常量明确标注 n,如 9007199254740991nNumber.MAX_SAFE_INTEGER 的BigInt形式)
  • 避免在需要浮点计算或与现有Number逻辑强耦合的场景中强行引入BigInt
  • 在支持BigInt的环境中(现代浏览器、Node.js ≥ v10.4.0),优先用字面量而非 BigInt() 构造函数,更简洁且性能略优

今天关于《BigInt数字后缀使用指南》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>