繁体   English   中英

Node JS Express-更新文档

[英]Node JS Express - updating documents

我已经通过http:// localhost:3000 / update2?buyerID = 2299实现了获取特定文档的检索。

当我按下提交时,它重定向到/ orders页面,从那里我可以查看所有记录以及当前字段。

如果我更改了检索和单击提交中的字段,则不会更新文档。它与以前相同。

5个JSON文档中的1个-http: //prntscr.com/dilrb0

JS文件

router.get('/update2', function(req, res) {
    var buyerID = req.query.buyerID;

    if (!buyerID || !parseInt(buyerID)) {
        res.render('error', {message: "You need to enter an ID to update a specific order", error:{status:"", stack: ""}});
    } else {

        mongoClient.connect(url, function (err, db) {
            if (err) {
                res.render('error', {message: "Failed to connect to MongoDB",error:{status:"", stack: ""}});
            } else {
                var WishList = db.collection('orders');
                WishList.findOne({"buyerID": parseInt(buyerID)}, function(err, result) {
                    if (err || !result || result.length == 0) {
                        res.render('error', {message: "Failed to find order",error:{status:"", stack: ""}});
                    } else {
                        res.render('updateOrder2', {qs: result});
                    }
                })
            }
        });
    }
});

router.post('/update2', function(req, res) {
    var buyerID = req.query.buyerID;

    if (!buyerID || !parseInt(buyerID)) {
        res.render('error', {message: "Failed to update order make sure the ID is current", error:{status:"", stack: ""}});
    } else {

        mongoClient.connect(url, function (err, db) {
            if (err) {
                res.render('error', {message: "Failed to connect to MongoDB", error:{status:"", stack: ""}});
            } else {
                var WishList = db.collection('orders');

                var order = {
                    buyerID: req.body.buyerID,
                    gender: req.body.gender,
                    student: req.body.student,
                    pName: req.body.pName,
                    type: req.body.type,
                    purchaseDate: req.body.purchaseDate,
                    price: req.body.price,
                    sName: req.body.sName

                };
                console.log("Updating..", order)
                WishList.updateOne({"buyerID": parseInt(buyerID)}, {$set: order}, function (err, result){
                    if (err) {
                        console.log("Cannot update", err)
                    } else {
                        console.log("Updated..", order)
                        res.redirect("/orders")
                    }
                })

            }
        });
    }
});

EJS

<!DOCTYPE html>
<html>
<head>
    <title>Update Recipe</title>
    <link rel='stylesheet' href='/stylesheets/style.css' />
</head>
<body>

<form name= "updateOrder" action="/updateOrder" method="POST">
    User ID:<br>
    <input type="text" name="buyerID" value = "<%=qs.buyerID%>" required ="required"><br>
    Gender:<br>
    <input type="text" name="gender" value = "<%=qs.gender%>" required ="required"><br>
    Student?:<br>
    <input type="text" name="student" value = "<%=qs.student%>" required ="required"><br>
    Product ID:<br>
    <input type="text" name="productID" value = "<%=qs.productID%>" required ="required"><br>
    Product Name:<br>
    <input type="text" name="pName" value = "<%=qs.pName%>" required ="required"><br>
    Product Type:<br>
    <input type="text" name="type" value = "<%=qs.type%>" required ="required"><br>
    Date Purchased:<br>
    <input type="text" name="purchaseDate" value = "<%=qs.purchaseDate%>" required ="required"><br>
    Product Price:<br>
    <input type="text" name="price" value = "<%=qs.price%>" required ="required"><br>
    Seller Name:<br>
    <input type="text" name="sName" value = "<%=qs.sName%>" required ="required"><br>
    <br><br>

    <input type="submit" value="Submit" />
</form>


</body>
</html>

我实际上对您在.post()开始时仍在使用req.query.buyerID而不是req.body.buyerID的事实感到困惑,但是代码显然仍然可以到达res.redirect(“ / orders “); 首先,请在您的updateOne中,尝试将parseInt(buyerID)替换为parseInt(order.buyerID)–克里斯·G 10小时前

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM