本文首发于我的个人博客: http://www.fogcrane.org

前言

本文将介绍的是Hexo的一个经典主题NexT的设置以及一些个性化定制。想了解该如何搭建博客的话可以前往我的上一篇博客:基于CentOS搭建Hexo博客。本文将延续上一篇博客进行展开。搭建完的效果就是我的博客效果,可点击传说门一睹为快~~

<!-- more -->

安装NexT

当你第一次初始化完Hexo时,默认的主题为landscape。本文将基于另一个主题NexT进行讲解,所以,首先应该安装主题NexT。
切换到博客根目录,打开Git Bash窗口,然后克隆NexT主题。代码如下:

git clone https://github.com/iissnan/hexo-theme-next themes/next

结果如图:

接下来到站点的设置文件_config.yml中启用主题NexT。修改以下字段:

theme: next

结果如图:

设置完毕之后,即可先在本地预览主题的运行效果。输入以下代码:

hexo clean
hexo g
hexo s

其中,hexo clean是为了清除数据库缓存等,每次修改了主题都需要进行此操作。hexo ghexo generate的简写,作用是生成静态文件。hexo shexo server的简写,作用是把hexo部署在本地服务器。所以可以在浏览器通过http://localhost:4000/对博客进行访问。
效果如图:

这里看到的效果,就是NexT的主题效果了,由于NexT默认启用的是Muse方案,所以看到的与我的博客效果差异略大,也比较ugly哈哈。接下来就开始主题配置之路了。

配置NexT

这里为了避免混淆,把博客根目录下的_config.yml文件称为站点配置文件,把themes/next目录下的_config.yml称为主题配置文件。配置工作正式开始。

开启NexT的Mist方案

打开主题设置文件themes/next/_config.yml,搜索字段scheme,然后把Mist对应的方案启用。效果如下图:


到这里,已经跟我的博客效果很接近了,接下来就是一些个性化定制了。

在右上角实现fork me on github

在右上角实现fork me on github,实现的效果如下图:

接下来说一下实现的方法:
首先,点击这里挑选一个你喜欢的样式,然后把对应的代码复制下来。
接着,打开文件:themes/next/layout/_layout.swig,搜索<div class="headband"></div>。然后把你刚刚复制的代码,粘贴到此处下面,并修改href为你的github的对应地址。如下图:

在文章末尾添加“本文结束”标记

1、打开目录themes/next/layout/_macro,新建文件passage-end-tag.swig。打开文件并输入以下代码后保存退出:

2、打开文件:themes/next/layout/_macro/post.swig,搜索post-footer,在此代码之前添加如下代码,效果如图:

<!-- 本文结束标记 -->
<div>
  {% if not is_index %}
    {% include 'passage-end-tag.swig' %}
  {% endif %}
</div>
<!-- 本文结束标记END -->

3、打开主题配置文件themes/next/_config.yml,在文件末尾添加以下代码,效果如图:

# 文章末尾添加“本文结束”标记
passage_end_tag:
  enabled: true

实现的效果如下图:

给文章添加阴影效果

打开文件themes/next/source/css/_custom/custom.styl,输入以下代码,保存后退出。

// 主页文章 添加阴影效果
.post {
   margin-top: 60px;
   margin-bottom: 60px;
   padding: 25px;
   -webkit-Box-shadow: 0 0 5px rgba(202,203,.5);
   -moz-Box-shadow: 0 0 5px rgba(202,204,.5);
}

效果如图:

隐藏底部Hexo标志

打开文件themes/next/layout/_partials/footer.swig,将对应代码进行注释,如下图:

新增访客统计及网站字数统计

1、安装依赖包,切换到博客根目录,打开Git Bash,输入以下代码安装字数统计包

npm install hexo-wordcount --save

2、打开文件:themes/next/layout/_partials/footer.swig,输入以下代码后保存退出。

<!-- 新增访客统计代码 -->
<div class="copyright" >
  {% set current = date(Date.Now(),"YYYY") %}
  &copy; {% if theme.since and theme.since != current %} {{ theme.since }} - {% endif %}
  <span itemprop="copyrightYear">{{ current }}</span>
  <span class="with-love">
    <i class="fa fa-balance-scale"></i>
  </span>
  <span class="author" itemprop="copyrightHolder">{{ config.author }}</span>
</div>

<div class="busuanzi-count">
    <script async="" src="https://dn-lbstatics.qBox.me/busuanzi/2.3/busuanzi.pure.mini.js"></script>
    <span class="site-uv">
      <i class="fa fa-user"></i>
      访问用户: <span class="busuanzi-value" id="busuanzi_value_site_uv"></span> 人
    </span>
    <div class="powered-by"></div>
    <span class="site-uv">
      <i class="fa fa-eye"></i>
      访问次数: <span class="busuanzi-value" id="busuanzi_value_site_pv"></span> 次
    </span>
    <!-- 博客字数统计 -->
    <span class="site-pv">
      <i class="fa fa-pencil"></i>
      博客全站共: <span class="post-count">{{ totalcount(site) }}</span> 字
    </span>
</div>
<!-- 新增访客统计代码 END-->

效果如图:

添加加载条

打开主题配置文件themes/next/_config.yml,搜索字段:pace,进行以下配置,如图:

添加宠物

1、安装依赖包,切换到博客根目录,打开Git Bash,输入以下代码安装live2d包

npm install --save hexo-helper-live2d

2、打开文件:themes/next/layout/_layout.swig,在</body>之前加入:{{ live2d() }},保存后退出。

3、打开站点配置文件,在末尾添加live2d的相关配置:

live2d:
  model: wanko
  width: 300
  height: 600
  horizontalOffset: 50
  position: left
  opacityDefault: 1
  scaling: 1.5
  mobileShow: false

效果如图:

关于live2d的配置,可以参考live2d的官方文档进行配置。

结语

目前只是配置了以上这些地方,更多个性化定制后续会持续更新,敬请留意~

基于CentOS搭建Hexo博客--设置NexT主题及个性化定制的更多相关文章

  1. html5录音功能实战示例

    这篇文章主要介绍了html5录音功能实战示例的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  2. 基于 HTML5 WebGL 实现的医疗物流系统

    物联网( IoT ),简单的理解就是物体之间通过互联网进行链接。这篇文章给大家介绍基于 HTML5 WebGL 实现的医疗物流系统,感兴趣的朋友跟随小编一起看看吧

  3. HTML5页面无缝闪开的问题及解决方案

    这篇文章主要介绍了HTML5页面无缝闪开方案,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  4. HTML5跳转小程序wx-open-launch-weapp的示例代码

    这篇文章主要介绍了HTML5跳转小程序wx-open-launch-weapp的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  5. ios – 与Xcode Bots持续集成

    我想使用Xcode机器人进行持续集成.我已经安装了OSXMavericks和Server(版本3).我可以使用Xcode5.0.1创建机器人.在集成时,它正在成功地执行分析测试,但总是最终的集成结果是失败的.IntegrationFailed.Unexpectedinternalservererror.Seetheintegration’slogsformoredetails.`我没有从服务器错误

  6. ios – 使用NSURLSession.downloadTaskWithURL时的内存泄漏

    或者,繁荣,内存泄漏.Apple的NSURLSession类参考在管理边框中的会话部分中指定:IMPORTANT—Thesessionobjectkeepsastrongreferencetothedelegateuntilyourappexitsorexplicitlyinvalidatesthesession.Ifyoudonotinvalidatethesession,yourappleaksmemoryuntilitexits.嗯是的.你也可以考虑这两种方法:>flushWithCompletio

  7. xcode – osx上的config.log是什么?它在哪里?

    任何人都可以解释’configure’是什么和做什么,一般可以找到config.log文件?

  8. ios – Swift Physics:碰撞时的角度计算错误

    我有一个简单的SpriteKit应用程序,带有墙壁和球.两者都设置了SKPhysicsBody.当我向一个方向施加力时,我希望球在碰撞时以相同的角度在墙壁上反射,但方向相反.但有时我看到角度很奇怪.我使用了所有的physicsBody属性,但是无法修复它.有时第一次反射看起来很好,但是第三次或第六次反射,有时第一次反射是错误的角度.我从不同的帖子中读到,人们有点自我计算的“正确方向”.但我无法想象

  9. Swift-ReactiveCocoa3.0二SignalProducer 2

    lift运算符|>内部也是调用了lift方法,作用是把原producer的结果transform完返回新的类型/值,再封装成新的producer返回。只有在第一个producer销毁后才会响应第二个producer。之后,每当其中一个再sendNext,都会在next回调zipwith压缩两个信号,每当两个都sendNext一次才回在next回调一次。例子:sampleOn采样,当sampleOn的信号sendNext一次,就取一次producer1的最新一次sendNext的值进行next回调takeu

  10. 如何在Swift中调用C函数

    “,选择Yes,创建SwiftCallC-Bridging-Header.h文件给工程建立一个C语言文件。跟上述步骤3类似,只不过这里选择的是C文件,这里的文件取名为CFile.c,同时自动生成CFile.h文件开始编写代码。在SwiftCallC-Bridging-Header.h文件中声明C函数,这里是voidcallCDemo()在CFile.c中定义这个函数在main.swift中调用这个C函数编译运行

随机推荐

  1. 在airgapped(离线)CentOS 6系统上安装yum软件包

    我有一个CentOS6系统,出于安全考虑,它已经被空气泄漏.它可能从未连接到互联网,如果有,它很长时间没有更新.我想将所有.rpm软件包放在一个驱动器上,这样它们就可以脱机安装而无需查询互联网.但是,我在测试VM上遇到的问题是,即使指定了本地路径,yum仍然会挂起并尝试从在线存储库进行更新.另外,有没有办法使用yum-utils/yumdownloader轻松获取该包的所有依赖项和所有依赖项?目前

  2. centos – 命名在日志旋转后停止记录到rsyslog

    CentOS6.2,绑定9.7.3,rsyslog4.6.2我最近设置了一个服务器,我注意到在日志轮换后,named已停止记录到/var/log/messages.我认为这很奇怪,因为所有日志记录都是通过rsyslog进行的,并且named不会直接写入日志文件.这更奇怪,因为我在更新区域文件后命名了HUPed,但它仍然没有记录.在我停止并重新启动命名后,记录恢复.这里发生了什么?

  3. centos – 显示错误的磁盘大小

    对于其中一个磁盘,Df-h在我的服务器上显示错误的空白区域:Cpanel表明它只有34GB免费,但还有更多.几分钟前,我删除了超过80GB的日志文件.所以,我确信它完全错了.fdisk-l/dev/sda2也显示错误:如果没有格式化,我该怎么做才能解决这个问题?并且打开文件描述符就是它需要使用才能做到这一点.所以…使用“lsof”并查找已删除的文件.重新启动写入日志文件的服务,你很可能会看到空间可用.

  4. 如何在centos 6.9上安装docker-ce 17?

    我目前正在尝试在centOS6.9服务器上安装docker-ce17,但是,当运行yuminstalldocker-ce时,我收到以下错误:如果我用跳过的标志运行它我仍然得到相同的消息,有没有人知道这方面的方法?

  5. centos – 闲置工作站的异常负载平均值

    我有一个新的工作站,具有不寻常的高负载平均值.机器规格是:>至强cpu>256GB的RAM>4x512GBSSD连接到LSI2108RAID控制器我从livecd安装了CentOS6.564位,配置了分区,网络,用户/组,并安装了一些软件,如开发工具和MATLAB.在启动几分钟后,工作站负载平均值的值介于0.5到0.9之间.但它没有做任何事情.因此我无法理解为什么负载平均值如此之高.你能帮我诊断一下这个问题吗?

  6. centos – Cryptsetup luks – 检查内核是否支持aes-xts-plain64密码

    我在CentOS5上使用cryptsetupluks加密加密了一堆硬盘.一切都很好,直到我将系统升级到CentOS6.现在我再也无法安装磁盘了.使用我的关键短语装载:我收到此错误:在/var/log/messages中:有关如何装载的任何想法?找到解决方案问题是驱动器使用大约512个字符长的交互式关键短语加密.出于某种原因,CentOS6中的新内核模块在由旧版本创建时无法正确读取512个字符的加密密钥.似乎只会影响内核或cryptsetup的不同版本,因为在同一系统上创建和打开时,512字符的密钥将起作用

  7. centos – 大量ssh登录尝试

    22个我今天登录CentOS盒找到以下内容这是过去3天内的11次登录尝试.WTF?请注意,这是我从我的提供商处获得的全新IP,该盒子是全新的.我还没有发布任何关于此框的内容.为什么我会进行如此大量的登录尝试?是某种IP/端口扫描?基本上有4名匪徒,其中2名来自中国,1名来自香港,1名来自Verizon.这只发生在SSH上.HTTP上没有问题.我应该将罪魁祸首子网路由吗?你们有什么建议?

  8. centos – kswap使用100%的CPU,即使有100GB的RAM也可用

    >Linux内核是否应该足够智能,只需从内存中清除旧缓存页而不是启动kswap?

  9. centos – Azure将VM从A2 / 3调整为DS2 v2

    我正在尝试调整前一段时间创建的几个AzureVM,从基本的A3和标准A3到标准的DS2v2.我似乎没有能力调整到这个大小的VM.必须从头开始重建服务器会有点痛苦.如果它有所不同我在VM中运行CentOS,每个都有一个带有应用程序和操作系统的磁盘.任何人都可以告诉我是否可以在不删除磁盘的情况下删除VM,创建新VM然后将磁盘附加到新VM?

  10. centos – 广泛使用RAM时服务器计算速度减慢

    我在非常具体的情况下遇到服务器速度下降的问题.事实是:>1)我使用计算应用WRF>2)我使用双XeonE5-2620v3和128GBRAM(NUMA架构–可能与问题有关!

返回
顶部