作爲每the JSON docs at Mozilla,JSON.Stringify
具有可用於過濾/忽略兒童物品在解析樹中的一個第二參數censor
。但是,也許你可以避免循環引用。
在Node.js中,我們不能。因此,我們可以做這樣的事情:
function censor(censor) {
var i = 0;
return function(key, value) {
if(i !== 0 && typeof(censor) === 'object' && typeof(value) == 'object' && censor == value)
return '[Circular]';
if(i >= 29) // seems to be a harded maximum of 30 serialized objects?
return '[Unknown]';
++i; // so we know we aren't using the original object anymore
return value;
}
}
var b = {foo: {bar: null}};
b.foo.bar = b;
console.log("Censoring: ", b);
console.log("Result: ", JSON.stringify(b, censor(b)));
結果:
Censoring: { foo: { bar: [Circular] } }
Result: {"foo":{"bar":"[Circular]"}}
遺憾的是似乎有一個最大的30次迭代之前,它會自動假定它是圓形的。否則,這應該工作。我甚至使用了areEquivalent
from here,但JSON.Stringify
仍然在30次迭代後拋出異常。儘管如此,如果你真的需要的話,還是可以在頂層獲得一個體面的對象代表。也許有人可以改善這一點呢?在Node.js的一個HTTP請求對象,我越來越:
{
"limit": null,
"size": 0,
"chunks": [],
"writable": true,
"readable": false,
"_events": {
"pipe": [null, null],
"error": [null]
},
"before": [null],
"after": [],
"response": {
"output": [],
"outputEncodings": [],
"writable": true,
"_last": false,
"chunkedEncoding": false,
"shouldKeepAlive": true,
"useChunkedEncodingByDefault": true,
"_hasBody": true,
"_trailer": "",
"finished": false,
"socket": {
"_handle": {
"writeQueueSize": 0,
"socket": "[Unknown]",
"onread": "[Unknown]"
},
"_pendingWriteReqs": "[Unknown]",
"_flags": "[Unknown]",
"_connectQueueSize": "[Unknown]",
"destroyed": "[Unknown]",
"bytesRead": "[Unknown]",
"bytesWritten": "[Unknown]",
"allowHalfOpen": "[Unknown]",
"writable": "[Unknown]",
"readable": "[Unknown]",
"server": "[Unknown]",
"ondrain": "[Unknown]",
"_idleTimeout": "[Unknown]",
"_idleNext": "[Unknown]",
"_idlePrev": "[Unknown]",
"_idleStart": "[Unknown]",
"_events": "[Unknown]",
"ondata": "[Unknown]",
"onend": "[Unknown]",
"_httpMessage": "[Unknown]"
},
"connection": "[Unknown]",
"_events": "[Unknown]",
"_headers": "[Unknown]",
"_headerNames": "[Unknown]",
"_pipeCount": "[Unknown]"
},
"headers": "[Unknown]",
"target": "[Unknown]",
"_pipeCount": "[Unknown]",
"method": "[Unknown]",
"url": "[Unknown]",
"query": "[Unknown]",
"ended": "[Unknown]"
}
我創建了一個小的Node.js模塊,在這裏做到這一點:https://github.com/ericmuyser/stringy隨意提高/貢獻!
您嘗試發送中有循環引用的對象。什麼是'pagedoc`? – 2011-01-27 12:10:38
你是什麼意思? – Skizit 2011-01-27 12:11:13
我的意思是什麼? 1.「pagedoc」的價值是什麼? 2.循環參考:`a = {}; a.b = a;` – 2011-01-27 12:13:28