首页 > 代码库 > Node.js 博客实例(九)标签和标签页面
Node.js 博客实例(九)标签和标签页面
原教程 https://github.com/nswbmw/N-blog/wiki/_pages的第九章,由于版本等的原因,在原教程基础上稍加改动即可实现。
每篇文章最多有三个标签(少于三个也可以),当点击主页左侧标签页链接时,跳转到标签页并列出所有已存在标签;当点击任意一个标签链接时,跳转到该标签页并列出所有含有该标签的文章。
首先我们来实现给文章添加标签的功能。
打开 post.ejs ,在 <input type="text" name="title" /><br /> 后添加:
<input type="text" name="tag1" /><input type="text" name="tag2" /><input type="text" name="tag3" /><br />打开 index.js ,将 app.post(‘/post‘) 内的:
var currentUser = req.session.user, post = new Post(currentUser.name, req.body.title, req.body.post);修改为:
var currentUser = req.session.user,
tags = [req.body.tag1, req.body.tag2, req.body.tag3],
post = new Post(currentUser.name, req.body.title, tags, req.body.post);
打开 post.js ,将:
function Post(name, title, post) { this.name = name; this.title= title; this.post = post; }修改为:
function Post(name, title, tags, post) { this.name = name; this.title = title; this.tags = tags; this.post = post; }将:
var post = { name: this.name, time: time, title: this.title, post: this.post, comments: [] };修改为:
var post = { name: this.name, time: time, title: this.title, tags: this.tags, post: this.post, comments: [] };现在我们就可以在发表文章的时候添加标签了。接下来我们修改 index.ejs 、 user.ejs 和 article.ejs 来显示文章的标签。
修改 index.ejs 、 user.ejs 和 article.ejs,将:
<p class="info"> 作者:<a href=http://www.mamicode.com/"/u/"> | >修改为:下一行添加:<p class="info"> 作者:<a href=http://www.mamicode.com/"/u/"> | >最后,在 style.css 中添加如下样式:.tag{background-color:#ff0000;border-radius:3px;font-size:14px;color:#ffffff;display:inline-block;padding:0 5px;margin-bottom:8px;} .tag:hover{text-decoration:none;background-color:#ffffff;color:#000000;-webkit-transition:color .2s linear;}至此,我们给博客添加了标签功能。
接下来我们给博客增加标签页。
修改 header.ejs ,在 <span><a title="存档" href=http://www.mamicode.com/"/archive">archive
<span><a title="标签" href=http://www.mamicode.com/"/tags">tags修改 index.js ,在 app.get(‘/archive‘) 后添加如下代码:
app.get('/tags', function (req, res) { Post.getTags(function (err, posts) { if (err) { req.flash('error', err); return res.redirect('/'); } res.render('tags', { title: '标签', posts: posts, user: req.session.user, success: req.flash('success').toString(), error: req.flash('error').toString() }); }); }); app.get('/tags/:tag', function (req, res) { Post.getTag(req.params.tag, function (err, posts) { if (err) { req.flash('error',err); return res.redirect('/'); } res.render('tag', { title: 'TAG:' + req.params.tag, posts: posts, user: req.session.user, success: req.flash('success').toString(), error: req.flash('error').toString() }); }); });打开 post.js ,在最后添加:
//返回所有标签 Post.getTags = function(callback) { mongodb.open(function (err, db) { if (err) { return callback(err); } db.collection('posts', function (err, collection) { if (err) { mongodb.close(); return callback(err); } //distinct 用来找出给定键的所有不同值 collection.distinct("tags", function (err, docs) { mongodb.close(); if (err) { return callback(err); } callback(null, docs); }); }); }); }; //返回含有特定标签的所有文章 Post.getTag = function(tag, callback) { mongodb.open(function (err, db) { if (err) { return callback(err); } db.collection('posts', function (err, collection) { if (err) { mongodb.close(); return callback(err); } //查询所有 tags 数组内包含 tag 的文档 //并返回只含有 name、time、title 组成的数组 collection.find({ "tags": tag }, { "name": 1, "time": 1, "title": 1 }).sort({ time: -1 }).toArray(function (err, docs) { mongodb.close(); if (err) { return callback(err); } callback(null, docs); }); }); }); };注意:这里我们用了 distinct (详见《mongodb权威指南》)返回 tags 键的所有不同值,因为有时候我们发表文章的标签是一样的,所以这样避免了获取重复的标签。
在 blog/views /文件夹下新建 tags.ejs ,添加如下代码:
<%- include header %> <% posts.forEach(function (tag, index) { %> <a class="tag" href=http://www.mamicode.com/"/tags/">>在 blog/views /文件夹下新建 tag.ejs ,添加如下代码:<%- include header %> <ul class="archive"> <% var lastYear = 0 %> <% posts.forEach(function (post, index) { %> <% if (lastYear != post.time.year) { %> <li><h3><%= post.time.year %></h3></li> <% lastYear = post.time.year } %> <li><time><%= post.time.day %></time></li> <li><a href=http://www.mamicode.com/"/u///">>为了保持和 post.ejs 一致。将 edit.ejs 修改为:<%- include header %> <form method="post"> 标题:<br /> <input type="text" name="title" value=http://www.mamicode.com/"" disabled="disabled" />
> 看看效果。发表文章的界面对了标签模块。我们来发表几篇文章测试一下。
点击左侧的标签,可显示出所有标签,点击其中一个标签,则列出所有含有该标签的文章:
点击 t1
Node.js 博客实例(九)标签和标签页面
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。