对象相互引用的时候如何序列化呢

对象相互引用的时候如何序列化呢

BUG集散地

2018-08-28 17:10 阅读 59 喜欢 0 json 对象引用 引用替换

背景:

java 对象中有很多引用,甚至会出现循环引用,比如 user 对象中有 school 对象,school 对象中又有 user 对象,这样在对 user 对象序列化的时候,就会出现死循环,导致内存溢出。通过一定的方式,将每个对象增加ID 和 REF 引用标识最终可以解决这个问题,生成类似下面的样式:

引用对象

这样就相当于给 user 对象增加一个 $id 标识,且值为 3,在school 中引用 user 对象的时候,只需要增加一个 $ref 值为 3的引用即可。 但是,序列化的字符串传递给前台后,生成的 JSON对象中还需要再替换回来,所以就有了 json 对象的引用替换。

解决思路:

将对象中的所有 $id 的对象取出放到容器中,然后将对象中所有包含 $ref 属性的对象,根据值替换为容器中的对象。(这里不考虑对象本身含有 $id 和 $ref 名称的属性)

代码:


<script type="text/javascript">
    var t = '{"name":"lixun","user":{"name":"xx","school":{"name":"sss","user":{"$ref":"3"}},"$id":"3"}}';
    var tt = '';
    var target = eval('('+t+')');
    console.log(target);
    var fixObject = function(target){
        var map = {};
        var scan = function(o){
            if(o.hasOwnProperty('$id')){
                var v = o['$id'];
                map[v] = o;
                // console.log(o.prototype.constructor);
            }
            //如果含有ID ,则为独立对象,需要对ref进行替换
            if(!$.isEmptyObject(o) && !$.isFunction(o) ){
                for(var n in o){
                    if(o.hasOwnProperty(n)){
                        if(o[n] instanceof Object){
                            scan(o[n]);
                        }    
                    }
                }
            }    
        };
        var replaceObj = function(o){
            if(o.hasOwnProperty('$ref')){
                var v = o['$ref'];
                o = map[v];
                return o;//关键点
            }
            if(!$.isEmptyObject(o) && !$.isFunction(o)){
                for(var n in o){
                    if(o[n] instanceof Object){
                        o[n] = replaceObj(o[n]);//关键点
                    }
                }
            }
            return o;
        };
        scan(target);
        console.log(map);
        replaceObj(target);
    };


    fixObject(target);
    console.log(target);


</script>

效果图:

效果图

这样就可以出现循环引用的效果了,而且所有的 $ref 属性的对象都可以查找到原本的值了。

转载请注明出处: https://chrunlee.cn/article/json-parse-convert-replace.html


如果对你有用的话,请赏给作者一个馒头吧 ...或帮点下页面底部的广告,感谢!!

赞赏支持
提交评论
评论信息(请文明评论)
暂无评论,快来快来写想法...
推荐
关于jquery,他的核心特点就是无new构造和链式调用,这里根据网上的资料,自己简单理解下,有助于消化核心代码。
web开发中,前台有时候会需要一个随机数或序列,通常来说,这个随机数可能只在当前页面中使用,并不需要太过严格,大体上重复率低即可。
之前一直没面试过前端,今天有一个,先整理下需要问的问题和答案。这里都是一些简单的问题,关于当下比较流行的框架并没有涉及到..
jsQR 是一款纯粹的由javascript实现的二维码识别库,可以在浏览器端使用,也可以在后端node.js环境使用。我之前使用过其他的识别库,例如:qrcode-reader 或其他,在使用上都比较麻烦,而且识别率并不高。jsQR是后来发现的,感觉(没有实际对比验证)jsQR识别率要更高些,使用起来也更简单,不需要安装其他依赖软件。
在项目开发过程中,分页是少不了的,之前封装了一个分页组件,样式是基于bootstrap的样式,当然也可以自己来修改
在页面中不同的frame之间进行相互调用的话,我们可以通过frame获取对应的window然后进行调用,但是如果是浏览器不同的tab之间呢?
最大公因数,也称最大公约数、最大公因子,指两个或多个整数共有约数中最大的一个。a,b的最大公约数记为(a,b),同样的,a,b,c的最大公约数记为(a,b,c),多个整数的最大公约数也有同样的记号。求最大公约数有多种方法,常见的有质因数分解法、短除法、辗转相除法、更相减损法。与最大公约数相对应的概念是最小公倍数,a,b的最小公倍数记为[a,b]。
Question from codewar,about all of array combinations.