代码拉取完成,页面将自动刷新
同步操作将从 李志远/node-curd 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
打开 post.js ,修改 Post.prototype.save 中要存入的文档为:
var post = {
name: this.name,
time: time,
title:this.title,
post: this.post,
comments: []
};
我们将 Post.getOne 函数里的:
doc.post = markdown.toHTML(doc.post);
修改为:
if (doc) {
doc.post = markdown.toHTML(doc.post);
doc.comments.forEach(function (comment) {
comment.content = markdown.toHTML(comment.content);
});
}
接下来我们在 models 下新建 comment.js 文件,添加如下代码:
var mongodb = require('./db');
function Comment(name, minute, title, comment) {
this.name = name;
this.minute = minute;
this.title = title;
this.comment = comment;
}
module.exports = Comment;
//存储一条留言信息
Comment.prototype.save = function(callback) {
var name = this.name,
minute = this.minute,
title = this.title,
comment = this.comment;
//打开数据库
mongodb.open(function (err, db) {
if (err) {
return callback(err);
}
//读取 posts 集合
db.collection('posts', function (err, collection) {
if (err) {
mongodb.close();
return callback(err);
}
//通过用户名、时间及标题查找文档,并把一条留言对象添加到该文档的 comments 数组里
collection.update({
"name": name,
"time.minute":minute,
"title": title
}, {
$push: {"comments": comment}
} , function (err) {
mongodb.close();
if (err) {
return callback(err);
}
callback(null);
});
});
});
};
修改 index.js ,在 Post = require('../models/post.js') 后添加一行代码:
Comment = require('../models/comment.js');
接下来我们创建 comment 的视图文件,在 views 文件夹下新建 comment.ejs ,添加如下代码(e.g. 首先要先插入一个留言再显示):
<br>
<!--留言的展示-->
<% post.comments.forEach(function(comment){ %>
<p>
<%= comment.name %>
<span class="info"> 回复于 <%= comment.time %></span>
</p>
<p><%- comment.content %></p>
<% })%>
<!--添加留言的表单-->
<% if (user) { %>
<form method="post" action="/comment/<%= post.name %>/<%= post.time.minute %>/<%= post.title %>">
发布人:<%= user.name %>
<input type="hidden" name="name" value="<%= user.name %>"/><br><br>
<textarea name="content" rows="5" cols="80"></textarea><br>
<input type="submit" value="留言" />
</form>
<% }else{ %>
<form method="post">
回应请先<a href="/login">登录</a>或<a href="/reg">注册</a>
<textarea name="content" rows="5" cols="80" id="tb"></textarea><br>
<input type="submit" value="留言" id="sb" />
</form>
<% } %>
<script>
window.onload = function(){
var textarea = document.querySelector('#tb');
var button = document.querySelector('#sb');
button.onclick = function(e){
e.preventDefault();
location.href = '/login';
}
textarea.onfocus = function(){
location.href = '/login';
}
}
</script>
打开 article.ejs ,在 <%- include footer %> 前添加一行代码:
<%- include comment %>
最后,修改 index.js ,注册留言的 POST 响应,在 app.get('/u/:name/:day/:title') 后添加如下代码:
app.post('/comment/:name/:minute/:title', function (req, res) {
var date = new Date(),
time = date.getFullYear() + "-" + (date.getMonth() + 1) + "-" + date.getDate() + " " +
date.getHours() + ":" + (date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes());
var comment = {
name: req.body.name,
time: time,
content: req.body.content
};
var newComment = new Comment(req.params.name, req.params.minute, req.params.title, comment);
newComment.save(function (err) {
if (err) {
req.flash('error', err);
return res.redirect('back');
}
req.flash('success', '留言成功!');
res.redirect('back');
});
});
注意:这里我们使用 res.redirect('back'); ,即留言成功后返回到该文章页。
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。