Как обновить данные MongoDB с помощью jQuery Ajax

#jquery #node.js #ajax #mongodb #body-parser

#jquery #node.js #ajax #mongodb #body-анализатор

Вопрос:

Я пытался обновить данные MongoDB (пользовательские данные) с помощью запроса PUT из Ajax, но не могу заставить его обновиться. Я не совсем уверен, как вводить данные в MongoDB, я просматривал многие вопросы stackoverflow, но я не мог найти свой ответ. Кроме того, я вроде как новичок в Ajax, поэтому любая помощь очень ценится! Спасибо.


Редактировать.ejs

     <% include ../partials/header %>

<h1>Edit your profile</h1>


<p id="updateData"></p>

<form method="POST"> 
    <input type="text" id="name" name="name" value="<%= user.name %>">
    <input type="text" id="email" name="email" value="<%= user.email %>">
    <a id="saveButton" href='javascript:void(0)' data-userid="<%= user._id %>">Edit</a>
</form>

<script>
    //Get/read

    $(function() {
        $("#saveButton").on('click', function () {
            var id = $(this).data("userid");
            var data = {
                name: $("#name").val(),
                email: $("#email").val()
            }
            $.ajax({
                method: "PUT",
                url: '/profile/'   id   "?_method=PUT",
                dataType: 'json',
                data: data
            }).success(function(data){
                updateData.append("<p>Response: Data saved!</p>");
                console.log("Successful!"   data);
            }).fail(function(data){
                console.log("Oops not working"   data);
            });
        });
    })
</script>


<% include ../partials/footer %>  
  

На стороне сервера (node.js )

 var express = require("express");
var router = express.Router({ mergeParams: true });
var User = require("../models/user"),
    { userIsLogged } = require('../config/auth'), // check if user is logged in
    { checkIfBlogOwner } = require('../config/auth'); // check if user is logged in


// UPDATE the Profile
router.put("/:id", userIsLogged, function (req, res) {

    var name = req.body.name;
    var email = req.body.email;

    User.findOneAndUpdate(req.params.id, { $set: { "name": name, "email": email } }, function (err, result) {
        if (err) {
            res.send("Error"   err);
        } else {
            // res.redirect("/profile/"   req.params.id);
            res.send("From router Put: Worked!");
        }
    });
});



//Global Router
module.exports = router;
  

Комментарии:

1. Какую ошибку он возвращает?

Ответ №1:

findOneAndUpdate ожидает в качестве первого аргумента объект, который задает критерии поиска. Таким образом, вам придется изменить свой запрос с этого:

 User.findOneAndUpdate(req.params.id, ...)
  

к этому

 User.findOneAndUpdate({_id: req.params.id}, ...)
  

Комментарии:

1. :facepalm: Большое вам спасибо!