JavaScript / GSON:通过对象图动态访问JSON引用(循环引用)
作者:互联网
由于几个循环引用,我遇到了通过Google GSON序列化Java对象的问题.我的所有尝试都以StackOverflowException结尾,因为GSON无法处理这些循环引用.
作为解决方案,我找到了以下GraphAdapterBuilder:
例:
https://groups.google.com/forum/#!topic/google-gson/z2Ax5T1kb2M
{
"0x1": {
"name": "Google",
"employees": [
"0x2",
"0x3"
]
},
"0x2": {
"name": "Jesse",
"company": "0x1"
},
"0x3": {
"name": "Joel",
"company": "0x1"
}
}
这工作得很好,但是我仍然无法通过对象图动态访问参考值(0xn),例如:
警报(0x3.company.name); – >应该打印“ Google”,但我只会收到未定义的信息
是否有可能实现这一目标?
也许使用自定义JSON.parse(ajaxResponse,function(key,value){}函数,它将变量替换为引用的对象树吗?
解决方法:
!更新,更好的解决方案!
如果可以切换库,则只需使用FlexJson>>> http://flexjson.sourceforge.net/.
我用自己的JSON解析器解决了我的问题:
在原始GraphAdapterBuilder中,“ ref”为“ 0x [n]”
资源:
$.ajax({
type: "POST",
url: "controller/ajaxmethod.htm",
data: { "var1": var1, "var2":var2},
success: function(response){
var jsonObject = parseGraphGSON(response, 0);
...
},
error: function(e){
alert('Error: ' + e.status);
}
});
function parseGraphGSON(gsonResponse, recursionLevel) {
var maxRecursionDepth = 2;
var jsonObject = JSON.parse(gsonResponse, function(key, value) {
if (typeof value === 'string') {
if (value.indexOf("ref") == 0) {
if (recursionLevel < maxRecursionDepth) {
return parseGraphGSON(gsonResponse, recursionLevel + 1)[value];
} else {
return JSON.parse(gsonResponse)[value];
}
}
}
return value;
});
return jsonObject;
}
标签:circular-reference,javascript,json,gson,serialization 来源: https://codeday.me/bug/20191010/1885766.html