Hexo 给Hexo Next添加本地搜索功能

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Hexo 给Hexo Next添加本地搜索功能相关的知识,希望对你有一定的参考价值。

参考技术A 在站点根目录下执行命令

编辑站点配置文件,新增以下内容到任意位置:

编辑主题配置文件,启用本地搜索功能:

注:三步缺一不可,尤其是记得把第三步的false改成true。

Hexo+NexT:Hexo第三方插件提供功能及配置

技术图片

本篇文章介绍NexT中通过第三方实现的功能,有的需要通过额外的插件,有的需要通过第三方提供的功能。这些功能丰富了网站内容,弥补了原生静态网站的不足。

Hexo博客专题索引页

增加百度统计分析功能

  1. 访问百度统计http://tongji.baidu.com网站,注册。进入管理菜单,在网站列表下面注册网站并获得访问代码如下。
<script>
var _hmt = _hmt || [];
(function() 
  var hm = document.createElement("script");
  hm.src = "https://hm.baidu.com/hm.js?ce33112f521e07dfe453757625e4XXXX";
  var s = document.getElementsByTagName("script")[0]; 
  s.parentNode.insertBefore(hm, s);
)();
</script>
  1. 这是一段JavaScript脚本代码。把它放入所有页面的<head>标签最前方,就可以实现访问统计,其中ce33112f521e07dfe453757625e4XXXX是你网站的标识码。

  2. 在NexT中,这段代码已经放入themes\\next\\layout\\_third-party\\analytics\\baidu-analytics.swig,通过include,当满足条件是就会植入页面头部。

  3. 主题配置中,设置baidu_analytics的值,也就是上面说的标识码,然后植入页面头部代码就会生效。

baidu_analytics: ce33112f521e07dfe453757625e4XXXX

利用插件实现字符统计及阅读时长估计

统计文章中的字符,根据字数估算阅读时间,这个功能是通过插件hexo-wordcount来实现的。

  1. 安装插件
npm install hexo-wordcount --save
  1. 打开主题配置文件进行配置
# Post wordcount display settings
# Dependencies: https://github.com/willin/hexo-wordcount
post_wordcount:
  item_text: true               # 是否显示“字数统计”及“阅读分钟”的文字
  wordcount: true               # 是否显示字数统计
  min2read: true                # 是否显示估算阅读分钟
  totalcount: true          # 是否在网站底部显示所有文章字数之和
  separated_meta: true  

效果如图

技术图片

用leancloud记录访问次数

NexT也集成了leancloud,在leancloud官网
中注册账号,获得app_key和app_id,然后在主题配置文件中进行如下配置。

# Show number of visitors to each article.
# You can visit https://leancloud.cn get AppID and AppKey.
leancloud_visitors:
  enable: true
  app_id: leanapp_id
  app_key: leanapp_key

然后在leancloud的控制台中的存储内添加一个Counterclass,这样就可以记录我们每页的浏览量了。

技术图片

网站评论系统需要维护用户,用户的留言,因此需要用到数据库。轻博客不具备这些功能,需要借助第三方提供的服务。

在NexT5.1.2版本中,集成了如下第三方的评论系统,只需要在主题配置中就可以打开相应功能。

  • disqus
  • 畅言
  • 多说
  • 有言
  • hypercomments
  • 来必力

其中disqushypercomments来必力是国外的,访问效果可能受影响,多说和有言好像也关闭了,畅言目前可用。

评论系统一个足够,在主题配置中进行相应配置,如果打开多个,会根据themes\\next\\layout\\_third-party\\comments\\index.swig中的顺序,前面配置成功,后面的就无效了。

以畅言为例,只需要在主题配置中打开下列配置。

changyan:
  enable: true  #打开开关
  appid:        #畅言系统网站上申请的appid
  appkey:       #畅言系统网站上申请的appkey

填入从畅言网站获得的appid和appkey即可开启评论。

给博客添加网站地图sitemap

搜索引擎每天让蜘蛛在网站爬行来抓取页面,网站地图的作用就是给主动给蜘蛛喂数据,网站地图位于网站根目录下,有sitemap.htmlsitemap.xml两种格式。百度搜索引擎及多数搜索引擎使用html格式,谷歌使用xml格式。
两步完成网站地图自动生成功能。

**安装网站地图生成插件**

npm install hexo-generator-sitemap --save

重新启动hexo,系统会在public根目录下生成sitemap.xml文件。

给网站设置RSS订阅

1、先安装 hexo-generator-feed 插件

$ npm install hexo-generator-feed --save

2、打开 站点配置文件 找到Extensions在下面添加

# RSS订阅
feed:
  type: atom
  path: atom.xml
  limit: 20
  hub:
  content:
  content_limit: 140
  content_limit_delim: ' '

3、打开 主题配置文件 找到rss,设置为

rss: /atom.xml

添加搜索功能

在网站内部提供搜索功能,可以进行全文搜索。

1、安装 hexo-generator-searchdb 插件

$ npm install hexo-generator-searchdb --save

2、打开 站点配置文件 找到Extensions在下面添加

# 搜索
search:
  path: search.xml
  field: post
  format: html
  limit: 10000

3、打开 主题配置文件 找到Local search,将enable设置为true

4、效果如图

技术图片

添加畅言评论系统

提供网站评论的网站很多,但由于是第三方免费服务,也许说停就停了。但既然是做静态网站博客,涉及到存储和交互的也只能采用第三方的了。

这里选择畅言作为第三方。

1、进入畅言官方网站注册。

2、登录完成之后,进入后台预览,下方找到畅言秘钥,获得APP KEYAPP ID

3、打开 主题配置文件 找到changyan,对应进行配置。

# changyan
changyan:
  enable: true
  appid: cyueKr
  appkey: a458c21e4100cfb443bf7f760a5

畅言需要网站做备案,但是你完全可以借用朋友已经备案的域名和备案号,通过审核后再改为自己的域名,然后备案下来了再修改回来。

hexo-neat压缩文件

hexo-neat作为一个hexo插件出现,他支持压缩html、css和js文件,可以消除hexo生成网页过程中留下大大片空白,压缩输出文件的体积。使用方法如下:

  1. 使用npm安装hexo-neat插件

    $ npm install hexo-neat --save
  2. 站点配置文件中打开开关。

    neat_enable: true  #打开总开关
    neat_html:      
      enable: true      #打开压缩html文件开关
      exclude:          #html的排除列表
    
    neat_css:          
      enable: true      #配置CSS文件开关
      exclude:
        - '**.min.css'   #配置排除文件  
    
    neat_js:
      enable: true       #js压缩开关
      mangle: true       #是否破坏文件名
      output:            #是否输出log日志,默认为true
      compress:
      exclude:
        - '*.min.js'     #js文件压缩排除列表

对于插件,除了日志输出外,用户基本无感。

技术图片

以上是关于Hexo 给Hexo Next添加本地搜索功能的主要内容,如果未能解决你的问题,请参考以下文章

《Hexo: 从零开始编写自己的主题》5. 添加本地搜索功能以及发布博客让官网接收

hexo next主题为博客添加分享功能

Hexo next主题安装algolia

Hexo NexT主题配置搜索功能教程

Hexo next博客添加折叠块功能添加折叠代码块

hexo博客添加功能