Hexo(sakura)设置文章置顶+私密文章

2023-10-09 23:50

本文主要是介绍Hexo(sakura)设置文章置顶+私密文章,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、前言

博客文章置顶是基于Next主题的优化:hexo博客优化之文章置顶+置顶标签

实践证明:直接按照轮子造车是开不了滴,
关键因素:在于sakura版本中,主题作者在themes\sakura\layout_partial\ archive.ejscategory-archive.ejs 中设置了:按照日期的排序法,不同主题的Hexo需要针对性设置哦!

二、文章置顶

  1. 卸载原有的主页加载插件

    npm uninstall hexo-generator-index --save
    
  2. 安装插件hexo-generator-index-pin-top

    npm install hexo-generator-index-pin-top --save
    
  3. 然后在需要置顶的文章的Front-matter中加上top: true即可。比如下面这篇文章:

    ---
    title: Hexo(sakura)设置文章置顶+置顶标签
    date: 2020-02-17 12:00:25
    categories: 技术
    top: true
    ---
    

    到目前为止,置顶功能按理说已经可以实现了;但是sakura主题有一点不同哦!

    关键因素:在于sakura版本中,主题作者在themes\sakura\layout_partial\ archive.ejscategory-archive.ejs 中设置了:按照日期的排序法,不同主题的Hexo需要针对性设置哦!

  4. sakura主题特有的设置themes\sakura\layout\_partial\下首页的显示:
    按date排序,这里需要单独修改archive.ejscategory-archive.ejs
    在这里插入图片描述

    4.14补充:
    Hexo(sakura)neat压缩导致首页归档页面分页处错位(完美解决)
    下面改不改pages=5没有任何影响,因为2就==2了,2>=2和 5>=2有什么区别呢。。。
    主题参考代码见:https://gitee.com/cungudafa/hexo-theme-sakuraplus


    3.5日补充:
    if (pagination == 2)部分是分页为2时才排序是不对的,
    应改为只要分页数大于1就分页if (pagination >= 2)

    不然文章写多了,超过三页会出现以下问题:
    在这里插入图片描述
    同理,在首页themes\sakura\layout\index.ejs也有一个Previous,把数值改大一点:(只是一个控制作用,不用改)
    在这里插入图片描述

    修改后完整archive.ejs

    <!-- 两篇文章以上 -->
    <% if (pagination >= 2){ %><!-- 置顶文章 --><% page.posts.each(function(post, index){ %><% if (post.top){ %><%- partial('_widget/index-items', {index: index, post: post}) %><% } %><% }) %><!-- 首页默认取最最新文章集 --><% page.posts.sort('date', theme.homePageSortType).limit(theme.homeArticleShown).each(function(post, index){ %><!-- 其余文章 --><% if (!post.top){ %><%- partial('_widget/index-items', {index: index, post: post}) %><% } %> <% }) %>
    <% } else { %><% page.posts.each(function(post, index){ %><%- partial('_widget/index-items', {index: index, post: post}) %><% }) %>
    <% } %>
    

    同理,修改后的category-archive.ejs

    ```
    <% if (pagination >= 2){ %><!-- 置顶文章 --><% page.posts.each(function(post, index){ %><% if (post.top){ %><%- partial('_widget/category-items', {index: index, post: post}) %><% } %><% }) %><!-- 首页默认取最最新文章集 --><% page.posts.sort('date', theme.homePageSortType).limit(theme.homeArticleShown).each(function(post, index){ %><!-- 其余文章 --><% if (!post.top){ %><%- partial('_widget/category-items', {index: index, post: post}) %><% } %> <% }) %>
    <% } else { %><% page.posts.each(function(post, index){ %><%- partial('_widget/category-items', {index: index, post: post}) %><% }) %>
    <% } %>
    ```
    

    现在,hexo clean && hexo g && hexo s可以查看到文章已经置顶了。
    为了置顶文章不那么突兀,现给置顶文章添加icon标识

  5. 首页添加置顶标签,位置:themes\sakura\layout\_widget\
    在这里插入图片描述
    index-items.ejscategory-items.ejs时间后添加

    <div class="p-time"><i class="iconfont icon-time"></i><%= date(post.date, 'YYYY-M-D') %>
    </div><div class="post-meta"><!--置顶 --><% if (post.top){ %><i class="fa fa-thumb-tack"></i><font color=ff9999>置顶</font><span class="post-meta-divider"> | </span><% } %>
    

    效果图:
    在这里插入图片描述
    文章内显示置顶:

    <% if (post.top){ %><i class="fa fa-thumb-tack"></i><font color=ff9999>置顶</font><% } %>
    

    效果:
    在这里插入图片描述

三、私密文章

  1. 安装插件

    npm install hexo-blog-encrypt --save
    
  2. 主配置文件MyWeb\_config.yml文末添加:

    # 文章加密
    encrypt:enable: truedefault_abstract: 这是一篇加密文章,内容可能是个人情感宣泄或者收费技术。如果你非常好奇,请与我联系。default_message: 输入密码,查看文章。
    

    启用博文加密。
    3-21修改: 去掉default_

    # 文章加密
    encrypt:enable: trueabstract: 这是一篇加密文章,内容可能是个人情感宣泄或者收费技术。如果你非常好奇,请与我联系。message: 输入密码,查看文章。
    
  3. 文章Front-matter中加上password: 123456即可:

    ---
    title: Hello World
    abbrlink: 3eeb
    password: 123456
    ---
    

    效果如下:
    在这里插入图片描述
    自定义提示语:

    ---
    title: Hello World
    abbrlink: 3eeb
    password: 123456
    abstract: 密码:123456
    message: 看不到吧,hhhh,不告诉你密码是123456
    ---
    

    其中:

    • password: 是该博客加密使用的密码
    • abstract: 是该博客的摘要,会显示在博客的列表页
    • message: 这个是博客查看时,密码输入框上面的描述性文字

    效果:(此页面是不支持复制功能的o!
    在这里插入图片描述
    如果你开启了 字数统计功能 的话,那么本文的统计也会失效。

  4. 加密文章,显示了评论,是不是很奇怪??
    需要额外隐藏浏览数、评论、作者信息等
    在这里插入图片描述
    在任何需要加密的地方加上一句:

    <% if (post.encrypt == true) { %>style="display:none" <% } %>
    

    例如:在这里插入图片描述
    在这里插入图片描述
    ps.需要时加上password,提示语message,abstract摘要,后两者不能设置为空哦。

这篇关于Hexo(sakura)设置文章置顶+私密文章的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/176449

相关文章

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

uniapp设置微信小程序的交互反馈

链接:uni.showToast(OBJECT) | uni-app官网 (dcloud.net.cn) 设置操作成功的弹窗: title是我们弹窗提示的文字 showToast是我们在加载的时候进入就会弹出的提示。 2.设置失败的提示窗口和标签 icon:'error'是设置我们失败的logo 设置的文字上限是7个文字,如果需要设置的提示文字过长就需要设置icon并给

Tomcat性能参数设置

转自:http://blog.csdn.net/chinadeng/article/details/6591542 Tomcat性能参数设置 2010 - 12 - 27 Tomcat性能参数设置 博客分类: Java Linux Tomcat 网络应用 多线程 Socket 默认参数不适合生产环境使用,因此需要修改一些参数   1、修改启动时内存参数、并指定J

java计算机毕设课设—停车管理信息系统(附源码、文章、相关截图、部署视频)

这是什么系统? 资源获取方式在最下方 java计算机毕设课设—停车管理信息系统(附源码、文章、相关截图、部署视频) 停车管理信息系统是为了提升停车场的运营效率和管理水平而设计的综合性平台。系统涵盖用户信息管理、车位管理、收费管理、违规车辆处理等多个功能模块,旨在实现对停车场资源的高效配置和实时监控。此外,系统还提供了资讯管理和统计查询功能,帮助管理者及时发布信息并进行数据分析,为停车场的科学

文章解读与仿真程序复现思路——电力自动化设备EI\CSCD\北大核心《考虑燃料电池和电解槽虚拟惯量支撑的电力系统优化调度方法》

本专栏栏目提供文章与程序复现思路,具体已有的论文与论文源程序可翻阅本博主免费的专栏栏目《论文与完整程序》 论文与完整源程序_电网论文源程序的博客-CSDN博客https://blog.csdn.net/liang674027206/category_12531414.html 电网论文源程序-CSDN博客电网论文源程序擅长文章解读,论文与完整源程序,等方面的知识,电网论文源程序关注python

linux下非标准波特率的设置和使用

通常,在linux下面,设置串口使用终端IO的相关函数设置,如tcsetattr等函数,linux内部有一个对常用波特率列表的索引,根据设置的波特率用底层驱动来设置异步通信芯片的寄存器 对于非标准的任意波特率需要用ioctl(fd, TIOCGSERIAL, p)和ioctl(fd, TIOCSSERIAL, p)的配合,ioctl的最后一个参数是struct serial_struct *

win7如何设置SATA硬盘

Win7在安装时设置的是IDE,安装完后需要在注册表中设置为SATA,否则直接设BIOS会不认硬盘,具体如下 注册表子项:HKEY_LOCAL_MACHINE/System/CurrentControlSet/Services/Msahci 找到Start键,将值0改为3

centOS7.0设置默认进入字符界面

刚装的,带有x window桌面,每次都是进的桌面,想改成自动进命令行的。记得以前是修改 /etc/inittab 但是这个版本inittab里的内容不一样了没有id:x:initdefault这一行而且我手动加上也不管用,这个centos 7下 /etc/inittab 的内容 Targets systemd uses targets which serve a simil

设置zookeeper开机自启动/服务化

设置启动zk的用户为zookeeper 设置启动zk的用户为zookeeper用户,而非root用户,这样比较安全。 可以使用root用户进行zookeeper的管理(启动、停止…),但对于追求卓越和安全的的人来说,采用新非root用户管理zookeeper更好。 步骤: 1. 创建用户和用户组 2. 相关目录设置用户和用户组属性 3. 采用zookeeper用户启动进程 设置z

如何设置好看的电脑屏保?电脑屏保设置教程

如何设置好看的电脑屏保?电脑屏保设置教程。大家好,今天小编给大家带来了好看的电脑屏保,教大家如何设置一个好看的电脑屏保。屏保软件很多,今天我们介绍一款比较有特殊的屁屏保软件:芝麻时钟(芝麻时钟 桌面时钟软件 桌面日历 时钟屏保 世界时钟软件下载芝麻时钟是很有个性的时钟软件,支持桌面时钟,任务栏时钟美化,世界时钟,桌面日历,桌面天气,记事便签,时钟屏保。把时钟放到桌面,选择自己喜欢的主题修改任务栏时