为了账号安全,请及时绑定邮箱和手机立即绑定

新增Hexo博客文章置顶功能

标签:
Html/CSS Linux
修改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 == 启动服务



作者:試毅_思伟


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
JAVA开发工程师
手记
粉丝
18
获赞与收藏
121

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消