关于前端:如何解决使用JSONstringify时遇到的循环引用问题

程序员在日常做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的原创文章,尽在:”汪子熙”:

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理