嗨,我正在浏览一个JSON数组,结果是在mongoDB中查询文档。 事实是,我有以下行为,我不知道为什么我得到这个:
in key: _bsontype |value: ObjectID
in key: id |value: S÷¯çò9þ w
in key: _bsontype |value: ObjectID
in key: id |value: S÷¯çò9þ h
in key: _bsontype |value: ObjectID
in key: id |value: S÷¯çò9þ h
in key: name |value: Default Process
in key: processType |value: Public
in key: id |value: BPMNDiagram_1
in key: name |value: procurement subprocess
正如你所看到的,这就是磨损...这是我的代码:
function changeIDs(json, map, count){
for(var key in json){
if(json.hasOwnProperty(key))
if(typeof json[key] === 'object')
changeIDs(json[key], map, count);
else{
console.log("in key: "+key + " |value: "+json[key]);
}
}
}
这是我的输入(json参数)的一部分:
[
{
"_id": "538df78eafe7f28d39fe2077",
"processId": "538df71bafe7f28d39fe2068",
"processMeta": {
"id": "538df71bafe7f28d39fe2068",
"name": "Default Process",
"processType": "Public"
},
"diagram": {
"id": "BPMNDiagram_1",
"name": "procurement subprocess"
},
"plane": {
"id": "BPMNPlane_1",
"bpmnElement": "538df71bafe7f28d39fe2068"
}
},
{other objects..},{other objects..}
]
是的,processId和_id是使用ObjectId函数生成的,看起来这里出现了问题,我对此不太确定,但我的猜测是每个_bsontype对应mongoSB对象ID,这是一个对象所以我的函数以递归方式进入...获取以下S÷¯çò9þ w
..,我是对的吗?
似乎我无法在我的for中获得“processId”和“_id”键,因此,我猜是我的_bsontype ... 所以最后,我的问题是,如何在没有获得结果的情况下浏览我的对象?,你必须看到有一个“id”属性包含垃圾数据,我不希望它在我的结果中查找例如,所有键ID,但仍然能够获取我的属性“processId”或“_id”的ObjectId.str值。
提前致谢。
答案 0 :(得分:7)
以防万一,如果将来其他一些不幸的家伙像我一样得到同样的问题。
正如你可以看到我的函数changeIDs得到3个参数,我只是改变了json参数,它应该是一个json(它是)你可以在我的问题中看到我的json输出为文本,所以它是有效的json,但我做了一个stringify字符串的解析..然后我再试一次..它正在工作。
那么解决方案呢? newJson = JSON.parse(JSON.stringify(json));
为什么呢?好吧,我更好的选择是,通过这种方式,当我们对对象进行字符串化时,它会以下列方式进行对象更改:
例如,如果json有一个对象DATE,则该对象将字符串化为Date.toString(),因此它将存储字符串表示。如果函数没有到字符串将是未定义的。
这就是为什么在完成stringify之后它正在工作,我的函数ObjectId()没有生存到我的stringify,但它转换为它包含的字符串值,即Mongo对象id值...