NodeJS MongoDB回调地狱

时间:2015-06-17 13:16:55

标签: node.js mongodb callback

我仍然遇到条件和数据库回调问题,我编写了一个查询违规对象的路由函数,这是来自客户端填写的表单。我试图更改拥有此违规的用户作为选项,我查询该用户并将其返回正常但是在if语句中,x!= y将始终返回true,因为我写这个的本质。我希望它完成查询,然后点击条件。我觉得有点不知道如何解决这个问题。

 if(viol.user != user[0]._id)

这样,当我编辑拥有该违规或对象的用户时,用户不会一遍又一遍地将相同的对象添加到自身。

app.post('/singleViolation/:violation', isAdmin, function(req, res) {
     var violation = req.params.violation;


     Violation.findById(violation, function(err, viol){
         if (err) throw err;
         if (req.body.cause === '') {
                req.body.cause = viol.cause;
            }
            if (req.body.date === '') {
                req.body.date = viol.date;
            }
            if (req.body.location === '') {
                req.body.location = viol.location;
            }


            if(req.body.email === '') {
                req.body.email == viol.user;
            }

            if( req.body.email != '') {

                User.find({"local.email" : req.body.email}, function (err, user) {


                    if (err) {
                        req.body.email = viol.user;
                    }

                    if(viol.user != user[0]._id) {
                        typeof viol.user;
                        typeof user[0].id;
                        console.log(viol.user);
                        console.log(user[0]._id);
                        console.log(viol.user === user[0].id);
                        viol.user = user[0];
                        viol.save();

                        user[0].local.violations.push(viol);
                        Vehicles.findById(viol.vehicle, function(err, veh) {

                            user[0].local.vehicles.push(veh);
                            veh.owner = user[0];
                            veh.save();
                            user[0].save();

                        });

                    }
                });
            }

            viol.cause = req.body.cause;
            viol.date = req.body.date;
            viol.location = req.body.location;

            viol.save();

     });
     res.json(req.body);
 });
app.get('/editViolations/:violations', isAdmin, function(req, res) {
    res.render('editViolations.ejs');
});

1 个答案:

答案 0 :(得分:2)

您需要使用事件才能达到您想要的效果。以下只是一个高级解决方案。

  • 查询结束时触发事件。
  • 将上述事件与您的条件陈述相关联。
  • 当您符合所需条件时触发另一项活动。
  • 将此活动与您的退货声明相关联。

阅读this好的tutplus博客,了解节点event module