如何使用ejs发布表单更新node.js和MongoDB应用程序中的现有用户数据?

时间:2019-01-30 00:59:54

标签: javascript node.js mongodb mongoose mongoose-schema

我对javascript极为陌生,找到了Brad Traversy的带有Passport Authentication的视频Node.js,然后将他的视频放到了t。

它对我有用,但是后来我想添加更多。我创建了一个自定义的仪表板和导航。我添加的一个页面是用户个人资料页面。之所以添加它,是因为我希望能够尽可能地更新用户的信息。

现在,我被卡住了。我认为我在路由index.js中放置的.findOneAndUpdate函数遇到问题。我可能没有正确使用该功能。我目前正在控制台记录req.body.name以及req.user.name。

req.body.name是用户输入的新名称,req.user.name是原始名称。

index.js的顶部和底部

const express = require('express');
const router = express.Router();
const { ensureAuthenticated } = require('../config/auth');
const mongoose = require('mongoose');
require('../models/User');
const User = mongoose.model('User');  

router.post('/', (req, res) => {
    updateRecord(req, res);
});

function updateRecord(req, res) {
User.findOneAndUpdate({ "_id": req.body._id },{
    $set: {
        "name": req.body.name
    }
 }, { new: true }, (err, doc) => {
    if (!err) { 

        console.log(req.user.name);
        console.log(req.body.name);
        res.redirect('/profile'); 
    }
    else {
        console.log('Error during record update : ' + err);
    }
 });
}



module.exports = router;

edit.ejs

<form action="./profile" method="POST">
<div class="form-group">
    <label for="">Full Name</label>
    <input type="text" class="form-control" value="<%= name %>" 
name="name"> 
</div>
<div class="form-group" >
    <label for="">email</label>
    <input type="text" class="form-control" value="<%= email %>" readonly>
</div>
<div class="form-row">
    <div class="form-group">
        <button type="submit" class="btn btn-info"><a href="profileEditor">  
</a> Save Changes</button>
    </div>
    <p>&nbsp; &nbsp;</p>
    <div class="form-group">
        <button class="btn btn-dismiss"><a href="./profile">Exit</a> 
</button></a>
    </div>
</div>
</form>

User.js

const mongoose = require('mongoose');

const UserSchema = new mongoose.Schema({
name: {
type: String,
required: true
},
email: {
type: String,
required: true
},
password: {
type: String,
required: true
},
date: {
type: Date,
default: Date.now
}
});

const User = mongoose.model('User', UserSchema);

module.exports = User;

编辑

我遵循了THEWOLF的指示,现在它正在更新到数据库! 但是,现在,当我单击“保存更改”按钮时,它将重定向到配置文件页面,但显示旧名称。仅当刷新页面或离开页面时,更新的名称才会显示在我的网站上。

这是新的index.js代码

router.post('/', (req, res) => {
   updateRecord(req,res);
   res.redirect('/profile');

});

function updateRecord(req, res) {
User.findOne({_id:req.user.id},(err,doc)=>{
 //this will give you the document what you want to update.. then 
doc.name = req.body.name;
doc.save(function(err,doc){

});

 });

1 个答案:

答案 0 :(得分:1)

在您需要的用户模型中做到这一点

const User=require('../models/User');

然后

function updateRecord(req, res) {
User.findOne({_id:req.body.id},(err,doc)=>{
 //this will give you the document what you want to update.. then 
doc.name = req.body.name; //so on and so forth

// then save that document
doc.save(callback);

});

}