考虑到之前的博客有置顶文章,所以需要置顶功能。

Google了一下解决方案,发现了本博客主题是支持置顶功能的,在需要置顶的Front-matter中加上top: true即可。试了一下,能置顶。。只是文章置顶在某一页而不是首页。。

期间看到了Pacman主题支持置顶,需要在_config.yml中配置好需要置顶的文章,略麻烦。

然后看到了next主题支持置顶,在博文front-matter中加上sticky: Sticky即可置顶,根据Sticky的大小来决定置顶顺序。

想实现next主题那样的功能,参考了一篇博文添加Hexo置顶功能的操蛋3小时,在hexo-generator-index中增加比较函数比较top值,我试了一下Bug还是有的,置顶文章后文章日期有些会乱掉(比较函数条件比较少)。

我自己写了一个比较函数,也有问题,后来查了一下Javascriptsort函数,其比较函数和C++的完全不同= =

C++的比较函数:

template<class T>bool cmp(T a, T b) {
    return  a < b; // 升序,降序的话就 b > a
}

Javascript的比较函数:

cmp(var a, var b) {
    return  a - b; // 升序,降序的话就 b - a
}

用了C++的比较函数,结果当然会出问题,期间都想重写js的排序函数了。。经过修改,已经能完美置顶了,只需要在front-matter中设置需要置顶文章的top值,将会根据top值大小来选择置顶顺序。(大的在前面)

以下是最终的node_modules/hexo-generator-index/lib/generator.js

'use strict';

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

module.exports = function(locals){
  var config = this.config;
  var posts = locals.posts;

    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; // 都没定义按照文章日期降序排

    });

  var paginationDir = config.pagination_dir || 'page';

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