为Hexo的增加置顶功能

主要操作

  • 修改generator.js文件
  • 在文章的front-matter中增加topsticky属性

操作方法

修改generator.js文件

修改node_modules\hexo-generator-index\lib\generator.js文件。
这个文件是控制生成文章的顺序的。修改成按 top排序。没有top,则按时间来排序。
文件内容如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
'use strict';

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

module.exports = function(locals) {
var config = this.config;
var posts = locals.posts.sort(config.index_generator.order_by);
var paginationDir = config.pagination_dir || 'page';
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; // 都没定义按照文章日期降序排
});
return pagination('', posts, {
perPage: config.index_generator.per_page,
layout: ['index', 'archive'],
format: paginationDir + '/%d/',
data: {
__index: true
}
});
};

增加topsticky属性

sticky 是让next主显示图钉样式的。
top 是来定义顺序的。

1
2
3
4
5
6
7
8
9
---
title: 为Hexo的增加置顶功能
tags: hexo
categories:
top: 1
sticky: 1
---

# title1

参考


为Hexo的增加置顶功能
https://blog.fengcl.com/2017/08/23/hexo-sticky/
作者
frank
发布于
2017年8月23日
许可协议