當前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
如何解决使用JSON.stringify时遇到的循环引用问题
生活随笔
收集整理的這篇文章主要介紹了
如何解决使用JSON.stringify时遇到的循环引用问题
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
程序員在日常做TypeScript/JavaScript開發時,經常需要將復雜的JavaScript對象通過JSON.stringify序列化成json字符串,保存到本地以便后續具體分析。
然而如果JavaScript對象本身包含循環引用,則JSON.stringify不能正常工作,錯誤消息:
VM415:1 Uncaught TypeError: Converting circular structure to JSON
解決方案,使用下面這段來自這個網站的代碼,定義一個全局cache數組,每當待序列化的JavaScript對象的屬性被遍歷時,將該屬性對應的值存儲到cache數組去。
如果遍歷時發現,有屬性值已經在cache數組里有值了,說明檢測到了循環引用,此時直接return退出循環即可。
var cache = []; var str = JSON.stringify(o, function(key, value) {if (typeof value === 'object' && value !== null) {if (cache.indexOf(value) !== -1) {// 移除return;}// 收集所有的值cache.push(value);}return value; }); cache = null; // 清空變量,便于垃圾回收機制回收使用這種辦法,我成功將一個存在循環引用的JavaScript對象序列化成字符串了。
更多Jerry的原創文章,盡在:“汪子熙”:
總結
以上是生活随笔為你收集整理的如何解决使用JSON.stringify时遇到的循环引用问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 微信键盘 macOS 灰度测试版 0.9
- 下一篇: 如何为我的VUE项目编写高效的单元测试-