我在使用JavaScript时遇到了奇怪的行为。我试图在JavaScript(node.js / express)
中构建这样的JS对象var docAudit = {date: nowObj, changed: {}};
docAudit.changed['N5'] = 'DieterDorian';
console.log(docAudit)按预期打印出来:
{ date: Thu Sep 04 2014 11:00:00 GMT+0200 (CEST),
changed: { N5: 'DieterDorian' } }
现在我想将这个docAudit对象推送或取消移动到我的历史记录中。数组在我的' ip' JSON(从mongoDB获取)
ip: {
__v: 15
_id: "53fb42bf52b6542527cb7d23"
aktuell: {
N5: "HansHerschel"
Auftragsnr: "2018"
}
historie: [
{
date: "2014-09-04T09:53:20.533Z"
changed: {
N5: "HansHerschel"
}
]
}
现在这个操作:
ip.historie.unshift(docAudit);
应该导致在' ip'内的historyie数组前面添加docAudit对象。 JSON对象。但是会发生什么:
ip: {
__v: 16
_id: "53fb42bf52b6542527cb7d23"
aktuell: {
// not important what happens here
}
historie: [
{
date: "2014-09-04T11:00:00.533Z"
changed: {
N5: "DieterDorian"
},
{
date: "2014-09-04T11:00:00.533Z"
},
{
date: "2014-09-04T09:53:20.533Z"
changed: {
N5: "HansHerschel"
}
]
}
所以会发生什么是一个额外的Date对象被推入历史记录'阵列。我想我可能正在构建“docAudit”#39;对象错误。预期的输出只是将docAudit推送到数组而没有额外的日期对象。
或者如果我打印出“' ip'对象console.log(ip)
:
{ changed: {}, date: Thu Sep 04 2014 11:48:51 GMT+0200 (CEST) },
{ date: Thu Sep 04 2014 11:48:51 GMT+0200 (CEST),
changed: [Object] } ] }
这是我的路由代码:
updateIP = function(req, res) {
return IP.findById(req.params.id, function(err, ip) {
if(!ip) {
res.statusCode = 404;
return res.send({ error: 'Not found' });
}
var docAudit = {'changed':{}, 'date': nowObj};
docAudit.changed.N5 = 'DieterDorian'
ip.historie.unshift(docAudit);
ip.markModified('aktuell');
ip.markModified('historie');
return ip.save(function(err) {
if(!err) {
console.log('Updated');
return res.send({ status: 'OK', ip:ip });
} else {
if(err.name == 'ValidationError') {
res.statusCode = 400;
res.send({ error: 'Validation error' });
} else {
res.statusCode = 500;
res.send({ error: 'Server error' });
}
console.log('Internal error(%d): %s',res.statusCode,err.message);
}
res.send(ip);
});
});
};
更新
我认为问题在于以下细分代码是否正确:
updateIP = function(req, res) {
return IP.findById(req.params.id, function(err, ip) {
// alter the ip JSON here...
ip.save(function(err) {
if(!err) {
return res.send({ status: 'OK', ip:ip });
}
}
});
}
答案 0 :(得分:1)
首先,你的' ip'结构不合适,我纠正了它:
ip:
{
__v: 15,
_id: "53fb42bf52b6542527cb7d23",
aktuell: {
N5: "HansHerschel",
Auftragsnr: "2018"
},
historie: [
{
date: "2014-09-04T09:53:20.533Z",
changed:
{
N5: "HansHerschel"
}
}
]
};
申请时,
var count = ip.historie.unshift(docAudit);
我得到了正确的预期结果,并将计数计为2。
{"__v":15,"_id":"53fb42bf52b6542527cb7d23",
"aktuell":{"N5":"HansHerschel","Auftragsnr":"2018"},
"historie":[
{"date":"x","changed":{"N5":"DieterDorian"}},
{"date":"2014-09-04T09:53:20.533Z","changed":{"N5":"HansHerschel"}}
]}
检查您是否正在进行两次升档。