为 hexo 增加置顶功能

hexo blog 没有提供置顶的功能, 但hexo作为一个优秀的开源项目, 代码架构和组织还是很清晰的, 有问题可以直接阅读或修改代码, 下面就通过修改代码来为hexo增加置顶功能.

修改index页的生成代码 generator.js

vim $SITE_HOME/node_modules/hexo-generator-index/lib/generator.js

增加以下排序代码:

posts.data = posts.data.sort(function(a, b) {
if(a.top && b.top) { // 两篇文章top都有定义
if(a.top == b.top) return b.date - a.date; // 若top值一样则按照文章日期降序排
else return b.top - a.top; // 否则按照top值降序排
}
else if(a.top && !b.top) { // 以下是只有一篇文章top有定义,那么将有top的排在前面(这里用异或操作居然不行233)
return -1;
}
else if(!a.top && b.top) {
return 1;
}
else return b.date - a.date; // 都没定义按照文章日期降序排
});

修改后的最终文件内容:

'use strict';

var pagination = require('hexo-pagination');

module.exports = function(locals){
var config = this.config;
var posts = locals.posts.sort('-date');
var paginationDir = config.pagination_dir || 'page';

// niko
posts.data = posts.data.sort(function(a, b) {
if(a.top && b.top) { // 两篇文章top都有定义
if(a.top == b.top) return b.date - a.date; // 若top值一样则按照文章日期降序排
else return b.top - a.top; // 否则按照top值降序排
}
else if(a.top && !b.top) { // 以下是只有一篇文章top有定义,那么将有top的排在前面(这里用异或操作居然不行233)
return -1;
}
else if(!a.top && b.top) {
return 1;
}
else return b.date - a.date; // 都没定义按照文章日期降序排
});
// niko

return pagination('', posts, {
perPage: config.index_generator.per_page,
layout: ['index', 'archive'],
format: paginationDir + '/%d/',
data: {
__index: true
}
});
};

测试置顶

找一篇你想置顶的博客, 在front-matter增加top: 1, top的value越大, 排在越前面, 如下:

title: JVM 常用GC算法简介
date: 2015-10-01 00:00:00
tags:
- JVM
- Java
categories2:
- Java
top: 1

okay, 启动你的 hexo server, 就可以看到置顶博客了:

参考


http://haozhe.site/2016/09/17/hexo%E5%8D%9A%E5%AE%A2%E8%AE%BE%E7%BD%AE%E7%BD%AE%E9%A1%B6/