Как передать одну схему в другую, используя MongoDB & Node.js - PullRequest
0 голосов
/ 10 июня 2019

Я пытаюсь опубликовать комментарии к сообщению в блоге, и эти комментарии являются массивом для каждого сообщения

Мне удалось получить комментарии к сообщению, но я не могу вызвать информацию из сообщения. Модель комментария содержит текст и автора, но комментарий принимает только авторскую часть модели. Когда комментарии появляются в сообщении, они показывают только имя пользователя, написавшего комментарий. Я проверил базу данных, и comment.text вообще не пропускается.

Комментарии Создать маршрут

router.post("/", ensureAuthenticated, (req, res) => {
    Blog.findById(req.params.id, (err, blog) => {
    if(err){
        console.log(err);
        res.redirect("/blog");
    } else {
        Comment.create(req.body.comment, (err, comment) => {
        if(err){
            req.flash("error", "Something went wrong");
            console.log(err);
        } else {
            //add username and id to comment
            comment.author.id = req.user._id;
            comment.author.name = req.user.name;
            comment.author.email = req.user.email;
            comment.save();
            //save comment
            blog.comments.push(comment);
            blog.save();
            req.flash("success", "Successfully added comment");
                    res.redirect("/blog/" + blog._id);
            }
        });
    }
    });
});

Схема комментариев

const mongoose = require("mongoose");
var commentSchema = new mongoose.Schema({
    text: String,
    author: {
        id: {
            type: mongoose.Schema.Types.ObjectId,
            ref: "User"
        },
        name: String,
        email: String
        }
});
module.exports = mongoose.model("Comment", commentSchema);

Часть страницы показа, которая показывает комментарий

<div class="card-body">
<% blog.comments.forEach(function(comment){ %>
    <div class="row">
        <div class="col-md-12">
        <strong><%= comment.author.name %></strong>
        <span class="float-right">10 days ago</span>
            <p class="card-text">
                <%= comment.text %>
                </p>
        <% if(user && comment.author.id.equals(user._id)) { %>
        <a class="btn btn-warning btn-sm d-inline-block" href="/blog/<%= blog._id %>/comments/<%= comment._id%>/edit">Edit</a>
        <form class="d-inline-block" action="/blog/<%= blog._id %>/comments/<%= comment._id%>?_method=DELETE" method="POST">
        <button class="btn btn-danger btn-sm">Delete</button>
        </form>
<% } %>
<hr>
    </div>
    </div>
<% }) %>
</div>

Я ожидаю, что на странице шоу будет отображаться текст каждого комментария.

1 Ответ

0 голосов
/ 11 июня 2019

Мне не хватало bodyParser. В случае, если у кого-то еще есть эта проблема, https://stackoverflow.com/a/55793723/8145657 исправил ее для меня.

...