继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

新增Hexo博客文章置顶功能

試毅_思伟
关注TA
已关注
手记 17
粉丝 18
获赞 121
修改Hexo文件夹下的node_modules/hexo-generator-index/lib/generator.js

需要添加的代码:

posts.data = posts.data.sort(function(a, b) {
      if(a.top && b.top) {
                if(a.top == b.top) return b.date - a.date;
                else return b.top - a.top;
      }
      else if(a.top && !b.top) {
                return -1;
      }      
      else if(!a.top && b.top) {
                return 1;
      }      
      else return b.date - a.date;
  });

以下是最终的generator.js内容:

'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);
  posts.data = posts.data.sort(function(a, b) {
      if(a.top && b.top) {
          if(a.top == b.top) return b.date - a.date;
          else return b.top - a.top;
      }
      else if(a.top && !b.top) {
          return -1;
      }
      else if(!a.top && b.top) {
          return 1;
      }
      else return b.date - a.date;
  });
  var paginationDir = config.pagination_dir || 'page';
  var path = config.index_generator.path || '';
  return pagination(path, posts, {
    perPage: config.index_generator.per_page,
    layout: ['index', 'archive'],
    format: paginationDir + '/%d/',
    data: {
      __index: true
    }
  });
};


如何使用:在需要置顶的文章添加top属性即可,排序从小到大

webp




博客效果:

webp


Tips:常用hexo命令
# hexo n == hexo new
# hexo g == 生成
# hexo s == 启动服务



作者:試毅_思伟


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP