识别 BigInt 序列化错误:JSON.stringify 深拷贝异常解决方法
时间:2026-05-19 22:30:39 248浏览 收藏
BigInt 类型因 JSON 标准不支持而无法被 JSON.stringify 序列化,会直接抛出明确的 TypeError 异常(提示“Do not know how to serialize a BigInt”),中断执行而非静默忽略,极易在深拷贝含大整数 ID 或高精度计数的场景中引发线上故障;本文直击该问题本质,详解如何通过控制台错误特征快速识别,并提供三种可靠解法——预处理过滤、定制 replacer 函数安全转换,以及优先推荐的现代 structuredClone() 原生方案,同时警示盲目兜底捕获的风险,助你彻底规避因 BigInt 序列化失败导致的数据错乱与隐性 Bug。

当你用 JSON.stringify 对含 BigInt 的对象做深拷贝时,会直接抛出 TypeError: Do not know how to serialize a BigInt。这不是静默丢失,而是明确中断执行的原始异常,必须捕获或提前规避。
为什么 BigInt 会触发报错
JSON 标准本身不支持 BigInt 类型(它只定义了 number,且等价于 IEEE 754 双精度浮点数)。JSON.stringify 在遇到无法表示的值时,不会跳过或转成 null,而是立即 throw 错误——这和 undefined、function、Symbol 的“静默忽略”行为完全不同。
例如:
const obj = { id: 123n };JSON.stringify(obj); // ⚠️ 抛出 TypeError
快速识别该错误的方法
- 在控制台或 Node.js 环境中运行时,错误堆栈中明确包含 "Do not know how to serialize a BigInt" 字样
- 使用
try...catch捕获时,error.name === 'TypeError'且error.message.includes('BigInt') - 若项目已接入错误监控(如 Sentry),该异常通常被归类为高频可定位的序列化失败类型
三种实用应对策略
- 提前过滤:深拷贝前遍历对象,将
typeof value === 'bigint'的字段转为字符串(value.toString())或安全数字(需确认是否超Number.MAX_SAFE_INTEGER) - 替换 replacer 函数:传入
JSON.stringify(obj, (key, val) => typeof val === 'bigint' ? val.toString() : val),避免中断,但注意返回的是字符串而非BigInt - 换用现代 API:Node.js 18.13+ / Chrome 115+ 支持
structuredClone(),它原生支持BigInt、Map、Set、Date等,且能处理循环引用(不抛错)
不推荐的“兜底”写法
不要用 JSON.stringify(obj) || '{}' 或未校验的 try...catch 吞掉错误——这会让 BigInt 问题隐身,后续逻辑可能因数据类型错乱而产生更隐蔽的 bug(比如字符串 ID 被误当数字参与计算)。
好了,本文到此结束,带大家了解了《识别 BigInt 序列化错误:JSON.stringify 深拷贝异常解决方法》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!
相关阅读
更多>
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
483 收藏
-
344 收藏
-
291 收藏
-
369 收藏
-
494 收藏
-
481 收藏
-
211 收藏
-
165 收藏
-
289 收藏
-
135 收藏
-
324 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习