Node.js 博客实例(十一)文章检索功能

原教程 https://github.com/nswbmw/N-blog/wiki/_pages的第十一章,由于版本等的原因,在原教程基础上稍加改动即可实现。

       现在我们来给博客增加文章检索功能,即根据关键字模糊查询文章标题,且字母不区分大小写。
首先,我们修改 header.ejs ,在 </nav> 前添加一行代码:

<span><form action="/search" method="GET"><input type="text" name="keyword" placeholder="SEARCH" class="search" /></form></span>
在 style.css 中添加一行样式:

.search{border:0;width:6em;text-align:center;font-size:1em;margin:0.5em 0;}
打开 post.js ,在最后添加如下代码:
//返回通过标题关键字查询的所有文章信息
Post.search = function(keyword, callback) {
	mongodb.open(function (err, db) {
			if (err) {
				return callback(err);
			}
			db.collection('posts', function (err, collection) {
				if (err) {
					mongodb.close();
					return callback(err);
				}
				var pattern = new RegExp("^.*" + keyword + ".*$", "i");
				collection.find({
						"title": pattern
					}, {
						"name": 1,
						"time": 1,
						"title": 1
					}).sort({
						time: -1
					}).toArray(function (err, docs) {
							mongodb.close();
							if (err) {
								return callback(err);
							}
							callback(null, docs);
						});
			});
	});
};
      注意:我们通过 pattern 定义了包含关键字 keyword 的正则表达式,若 keyword 字符串的开头或结尾包含特殊字符(比如说 * )则需转义。
修改 index.js ,在 app.get(‘/u/:name‘) 前添加如下代码:
        app.get('/search', function (req, res) {
		Post.search(req.query.keyword, function (err, posts) {
			if (err) {
				req.flash('error', err); 
				return res.redirect('/');
			}
			res.render('search', {
				title: "SEARCH:" + req.query.keyword,
				posts: posts,
				user: req.session.user,
				success: req.flash('success').toString(),
				error: req.flash('error').toString()
			});
		});
	});
在 views 文件夹下新建 search.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="/u/<%= post.name %>/<%= post.time.day %>/<%= post.title %>"><%= post.title %></a></li>
<% }) %>
</ul>
<%- include footer %>
       注意:目前为止,你会发现 tag.ejs 和 search.ejs 代码完全一样,因为我们都用相同的布局。这也突出了模版的优点之一 —— 可以重复利用,但我们这里并没有把这两个文件用一个代替,因为每一个文件的名字代表了不同的意义。

效果:输入查询关键字,


查询结果:



郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。