首页前端开发JavaScript详解如何解决使用JSON.stringify时遇到的循环引用问题

详解如何解决使用JSON.stringify时遇到的循环引用问题

时间2024-02-01 04:51:03发布访客分类JavaScript浏览686
导读:收集整理的这篇文章主要介绍了详解如何解决使用JSON.stringify时遇到的循环引用问题,觉得挺不错的,现在分享给大家,也给大家做个参考。 程序员在日常做TyPEScript/Jav...
收集整理的这篇文章主要介绍了详解如何解决使用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对象序列化成字符串了。

到此这篇关于详解如何解决使用JSON.stringify时遇到的循环引用问题的文章就介绍到这了,更多相关JSON.stringify 循环引用内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

您可能感兴趣的文章:
  • JS如何对Iframe内外页面进行操作总结
  • 如何让js中的if判断如丝般顺滑详解
  • 简易版本JSON.stringify的实现及其六大特性详解
  • JSON.stringify的多种用法总结
  • Vue实现在线预览pdf文件功能(利用pdf.js/iframe/embed)
  • JavaScript JSON.stringify()的使用总结
  • json.stringify()与json.parse()的区别以及用处
  • Selenium+BeautifulSoup+json获取Script标签内的json数据
  • 关于JavaScript 中 if包含逗号表达式

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: node中使用shell脚本的方法步骤下一篇:浅谈react路由传参的几种方式猜你在找的JavaScript相关文章 html font标签如何设置字体大小?html font标签属性用法介绍2022-05-16vue3+TypeScript+vue-router的使用方法2022-04-16vue3获取当前路由地址2022-04-16如何利用React实现图片识别App2022-04-16JavaScript展开运算符和剩余运算符的区别详解2022-04-16微信小程序中使用vant框架的具体步骤2022-04-16Vue elementUI表单嵌套表格并对每行进行校验详解2022-04-16如何利用Typescript封装本地存储2022-04-16微信小程序中wxs文件的一些妙用分享2022-04-16JavaScript的Set数据结构详解2022-04-16 其他相关热搜词更多phpjavapython程序员loadpost-format-gallery

若转载请注明出处: 详解如何解决使用JSON.stringify时遇到的循环引用问题
本文地址: https://pptw.com/jishu/594943.html
vue实现密码显示隐藏功能的思路详解 C#中使用SQLite数据库的方法介绍

游客 回复需填写必要信息