Hexo Next主题博客功能完善

本篇已同步到 个人博客 ,欢迎常来。

前提为你已经搭建好hexo next博客
如果没有,则参考搭建吧
注意:下载next地址变了next新地址
博客部署命令可以用&&操作:

  • hexo clean && hexo g && hexo s
  • hexo clean && hexo g && hexo d
    !!!很多插件安装,网上的如果不行,请直接参考插件官网,最官方

一、配置问题注意点

1. 文章显示中文

根目录/_config.yml(不是next下面的哈)
language: zh-CN # 是zh-CN 不是zh-Hans

2. 首页显示阅读全文

themes/next/_config.yml

auto_excerpt:
  enable: true # 设置是否显示阅读全文,文章较多的话,有必要设置为 true
  length: 200 #预览展示多少文字

3. 分享功能

ps:微信图片加载不出来,所以去掉了

Step1

source/lib
git clone https://github.com/theme-next/theme-next-needmoreshare2 source/lib/needsharebutton
ps:名字不是随便的needsharebutton


Step2

needmoreshare2:
  enable: true
  postbottom:
    enable: true
    options:
      iconStyle: box
      boxForm: horizontal
      position: bottomCenter
      networks: Weibo,Douban,QQZone,Twitter,Facebook
  float:
    enable: true
    options:
      iconStyle: box
      boxForm: horizontal
      position: middleRight
      networks: Weibo,Douban,QQZone,Twitter,Facebook

4. 添加分类和标签

官方链接
参考链接

4.1. 添加分类

Step1

进入博客所在文件夹
执行 : hexo new page categories
成功提示 : INFO  Created: ~/Documents/blog/source/categories/index.md
根据上面的路径,找到index.md这个文件,打开后默认内容是这样的:

---
title: 文章分类
date: 2017-05-27 13:47:40
---

添加type: "categories"到内容中,添加后是这样的:
---
title: 文章分类
date: 2017-05-27 13:47:40
type: "categories"
---


新建文章后 hexo new [post] 文章标题
添加categories属性,再部署之后就可以在分类页看到分类了
---
title: hexo next 为文章添加分类
date: 2016-03-16 08:12:43
tags:
categories: 前端
---
或则这样但是分类只能添加一个
---

title: hexo next 为文章添加分类
date: 2016-03-16 08:12:43
tags:
categories: 
- 前端
---

4.2. 添加标签

Step1
进入博客所在文件夹
hexo new page tags

成功后提示
INFO  Created: ~/Documents/blog/source/tags/index.md

根据上面的路径,找到index.md这个文件,打开后默认内容是这样的:
---
title: 标签
date: 2017-05-27 14:22:08
---

添加type: "tags"到内容中,添加后是这样的:

---
title: 文章分类
date: 2017-05-27 13:47:40
type: "tags"
---

Step2
新建文章或者想给某个文件添加tags,则如下操作
---
title: jQuery对表单的操作及更多应用
date: 2017-05-26 12:12:57
categories: 
- web前端
tags:
- jQuery
- 表格
- 表单验证
---

注意:
1.只有添加了tags: xxx的文章才会被收录到首页的“标签”中。
2.在categories和tags的index.m文件里面添加
comments: false ,把评论关了

细心的朋友可能已经发现,这两个的设置几乎一模一样!是的,没错,思路都是一样的。所以我们可以打开scaffolds/post.md文件,在tages:上面加入categories:,保存后,之后执行hexo new 文章名命令生成的文件,页面里就有categories:项了。

scaffolds目录下,是新建页面的模板,执行新建命令时,是根据这里的模板页来完成的,所以可以在这里根据你自己的需求添加一些默认值。

5. 文章侧边栏控制

# 这个地方控制自动打开文章目录条
# #sidebar: 注释掉则表示一打开详情页不会自动弹出sidebar
    sidebar:

6. 不要Next自动添加序号

themes/next/_config.yml 修改 number: false

toc:
  enable: true

  # Automatically add list number to toc.
  # 不要next系统添加序号
  number: false #true

  # If true, all words will placed on next lines if header width longer then sidebar width.
  wrap: false

7.代码高亮主题色

需要写明语言才会真正有效果
hexo next highlight_theme 设置

8. 安装与卸载插件

8.1. 安装

npm install xxx –save
做相应配置(官网)

8.2. 卸载

npm uninstall 插件名称 --save
去掉相应配置(安装时候配置的)

例: 卸载hexo s上传图片到的七牛插件(个人安装又卸载了)
npm uninstall hexo-qiniu-sync --save
去掉根目录/_config.yml下配置

9.网页加载动画效果

PS: next 已经集成好动画了,如果对速度有要求的话直接关闭,个人选择关闭,加载太慢了。

# 加载有点慢 关掉
motion:
  enable: false #true

10. 如何在首页添加图片

参考链接

每篇文章里面添加photos: —"图片链接"

---
layout: '[post]'
title: Next主题博客功能完善
date: 2018-08-07 00:25:53
tags:
- 博客
- 技巧
categories: 博客搭建
photos: 
    - "http://oz2tkq0zj.bkt.clouddn.com/17-11-9/52323298.jpg"
---

二、 添加功能插件

1. 图片浏览放大功能fancybox

Step1:

cd next/source/lib
git clone https://github.com/theme-next/theme-next-fancybox3 fancybox

ps:注意fancybox和next/_config.uml里面的名字保持一致

step2:
更改next/_config.uml文件

fancybox: true

2. 阅读次数

ps: 仅限于博文详情页面显示阅读数,在首页不显示

step1
更改next/_config.uml文件enable: true,如下:

busuanzi_count:
  enable: true #false
  total_visitors: true
  total_visitors_icon: user
  total_views: true
  total_views_icon: eye
  post_views: true
  post_views_icon: eye

3. hexo s 顺便上传图片到七牛云服务器参考

ps:这个插件感觉可添加也可不用添加,用到图片的时候自己上传到七牛服务器就好

step1:
自己注册七牛服务器(目前笔者觉得够用了)

step2:
hexo主目录,下载插件
npm install hexo-qiniu-sync --save

step3:
配置next/_config.yml
#七牛云存储设置
##offline       是否离线. 离线状态将使用本地地址渲染
##sync          是否同步
##bucket        空间名称.
##access_key    上传密钥AccessKey
##secret_key    上传密钥SecretKey
##secret_file   秘钥文件路径,可以将上述两个属性配置到文件内,防止泄露,json格式。绝对路径相对路径均可
##dirPrefix     上传的资源子目录前缀.如设置,需与urlPrefix同步 
##urlPrefix     外链前缀.
##up_host      上传服务器路径,如选择华北区域的话配置为http://up-z1.qiniu.com
##local_dir     本地目录.
##update_exist  是否更新已经上传过的文件(仅文件大小不同或在上次上传后进行更新的才会重新上传)
##image/js/css  子参数folder为不同静态资源种类的目录名称,一般不需要改动
##image.extend  这是个特殊参数,用于生成缩略图或加水印等操作。具体请参考http://developer.qiniu.com/docs/v6/api/reference/fop/image/ 
##              可使用基本图片处理、高级图片处理、图片水印处理这3个接口。例如 ?imageView2/2/w/500 即生成宽度最多500px的缩略图
qiniu:
  offline: false
  sync: true
  bucket: bucket_name
  secret_file: sec/qn.json or C:
  access_key: AccessKey
  secret_key: SecretKey
  dirPrefix: static
  urlPrefix: http://bucket_name.qiniudn.com/static
  up_host: http://upload.qiniu.com
  local_dir: static
  update_exist: true
  image: 
    folder: images
    extend: 
  js:
    folder: js
  css:
    folder: css
    
    
step4:
在hexo目录下,运行一下hexo s,图片直接上传到七牛云存储上去了

注意:备份发布系统代码不会上传hexo-qiniu-sync,不过在重新下载了部署系统,则直接运行npm install hexo —save就好,不需要再次执行 npm install hexo-qiniu-sync --save 因为在第一次下载的时候已经在配置文件记录了

4. 畅言评论插件集成参考

功能:博客下面进行各种登陆评论,首页及详情页顶部评论量显示

4.1.畅言集成步骤

step1:
注册畅言:http://changyan.kuaizhan.com/
获取畅言评论的APP ID 和APP KEY
ICP备案:自己有最好,网上随便找一个

step2:
集成就不详叙,直接参考:https://www.jianshu.com/p/5888bd91d070

遇到的坑 :
a. 显示不全


Hexo Next主题博客功能完善_第1张图片
image

解决办法:
更改next/layout/_partials/comments.swig代码
原来的代码: 34行处

改完后的代码:

b. 首页显示评论出现问题参考解法

解决办法:
next/layout/_mavro/post.swig:175~178行


                 
               

将post.permalink这个值包一层encodeURI方法


4.2. 我为什么最终选畅言而不其他评论插件,其他评论插件我都集成过?

(ps:下面的言论不代表其余的评论插件做的不行,很可能是我的集成姿势不对)

先说说我集成评论系统的要求:
登陆评论方便、首页/详情页评论数显示正确

4.2.1. gitment集成参考: id获取问题导致如果同时发布两篇文章,两篇文章下显示的评论都是两篇文章的总合

Error:validation failed 解决办法如下

文件:themes\next\layout_third-party\comments\gitments.swig
替换 id: window.location.pathname,
方法一:id: '{{ page.date }}’,
方法二:id: (window.location.pathname.length < 50) ? window.location.pathname : '<%= page.date %>',

function renderGitment(){
    var gitment = new {{CommentsClass}}({
        id: window.location.pathname,
        owner: '{{ theme.gitment.github_user }}',
        repo: '{{ theme.gitment.github_repo }}',
        {% if theme.gitment.mint %}
            lang: "{{ theme.gitment.language }}" || navigator.language || navigator.systemLanguage || navigator.userLanguage,
            {% endif %}

4.2.2. 来必得集成参考

插件集成最简单,但是因为是韩国的所以加载比较慢,首页没有评论数量显示所以没
用。

4.2.3. valine集成参考

集成也挺简单,但是评论的时候让用户直接选择留下联系方式,然后没有首页显示评论数量所以没用,且评论管理不知道在哪里管理;

5. 本地搜索功能

local_search

方法一:推荐官方教程

Step1: 
cd 到博客根目录
npm install hexo-generator-searchdb --save

Step2:
根目录/_config.yml 文件下添加下面代码
search:
  path: search.xml
  field: post
  format: html
  limit: 10000
  
Step3:
next/_config.yml 文件下更改以下代码:改false为true
local_search:
  enable: true #false

方法二:民间教程

step1: 安装插件

插件管理方法一:自己管理
cd next/source/lib
git clone https://github.com/theme-next/hexo-generator-searchdb.git local_search 
ps:local_search名字和里面对应

方法二:直接让npm给你管理插件-- 推荐
npm install hexo-generator-searchdb --save



Step2
your root _config.yml 添加:
search:
  path: search.xml
  field: post
  format: html
  limit: 10000
  
step3
/next/_config.yml 改local_search为true
local_search:
  enable: true

6. 文字数量和阅读时长

Step1
npm install hexo-symbols-count-time --save



  
Step2

your root _config.yml
symbols_count_time:
  symbols: true
  time: true
  total_symbols: true
  total_time: true
  
  
/next/_config.yml 不用动

7. 开启RRS订阅

ps:Next主题默认就支持插件git 参考链接

Step1
cd博客根目录安装 RSS 插件
npm install hexo-generator-feed --save

Step2
开启网站 RSS 支持

编辑网站根目录下的 _config.yml,添加以下代码开启

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


你可能感兴趣的:(Hexo Next主题博客功能完善)