• 我的Hexo-Github博客搭建笔记


    从零开始搭建个人博客

    点击进入我的博客查看效果

    安装依赖包node.js

    Hexo是一款基于Node.js的静态博客框架, 所谓巧妇难为无米之炊,要想搭建上层的博客必须先安装底层的node.js,可以直接上node.js官网下载安装,该安装包除了node.js之外还包括node软件包管理工具npm

    后面我们需要用npm来安装hexo相关模块,而在国内首先需要像pip那样更换镜像,如下更换为淘宝镜像:

    npm config set registry https://registry.npm.taobao.org
    

    安装hexo

    使用终端命令安装hexo客户端,如下

    npm install -g hexo-cli
    

    然后本地新建一个文件夹如blogs,并cd到该路径,执行初始化

    hexo init
    

    考虑到每个人命名方式不同,blogs/这里我称为hexo的根目录

    利用本地服务器生成网页

    利用PC端生成服务器开启网页,比后面部署到github pages上刷新要快,可用于测试

    先新建一个题为test的博客,即

    hexo n test
    

    此时会在主目录source/_posts下生成一个test.md文件,就是我们的第一篇博客test,编辑保存后生成相应网页文件,如下

    hexo g
    

    然后开启服务器

    hexo s
    

    点击http://localhost:4000就可以看到博客网页,终端CTRL+C则关闭本地服务器。

    部署到Github Pages

    本地服务器生成的网页别人是没法看到的,因此可以选择部署到github pages上。

    首先Github网页上新建一个repo,名字严格为用户民.github.io,比如我的用户名为JohnJim0816,则相应的仓库名为JohnJim0816.github.io

    然后本地主目录blogs下,终端运行如下命令安装hexo-deployer-git。

    npm install hexo-deployer-git --save
    

    然后在主目录的配置文件_config.yml中(这里称之为站点配置文件,后面还有一个同名的主题配置文件),找到deploy部分,并更改如下,注意repo部分根据个人github用户名(我的为JohnJim0816)而定。

    deploy:
      type: git
      repo: https://github.com/JohnJim0816/JohnJim0816.github.io
      branch: master
    

    配置完成之后,使用hexo n test新建一个博客。
    然后hexo g生成,然后hexo d发布,也可以hexo g -d将两步合为一步。然后需要等待一段时间,就可以在https://johnjim0816.github.io/看到自己的博客了。

    image1

    安装next主题来装点博客

    hexo自带的主题是landscape,对应带主目录themes文件夹下,这个主题只能说是平平无奇!!!

    因此需要安装一个靓靓的主题来使我们的博客秀色可餐,这里推荐github上star较多的next主题。

    截止2020年4月10日该主题已经更新到了v7.8.0。注意还有一个iissnan/hexo-theme-next,这个虽然star很多,并且网上的很多教程是跟这个主题关联的,但是已经不维护了,所以还是推荐前面一个。

    可以直接下载整个仓库并在本地解压,将名字改为next,然后放到博客根目录下的themes文件夹下。

    在站点配置文件即blogs/_config.yml中将语言更改为中文,如下,注意冒号之后有一个空格

    language: zh-CN
    

    并且将主题改为next:

    theme: next
    

    保存之后使用hexo g -d可以看到初步效果,不过github pages刷新较慢,因此测试优化博客网页时建议在本地服务上进行。

    后续优化

    首先阅读Hexo官方文档

    官方文档虽然有时候难啃,但是给出的方法总是最新最不容易走坑的。个人认为官方文档中的以下几点有必要关注一下:

    • 配置:即通过对上文所说的博客根目录下的站点配置文件_config.yml来修改大部分配置,包括网站标题等等,注意每次修改该配置文件后需要hexo clean之后才能通过hexo g生效。
    • 写作:关注scaffolds文件夹下的模版文件,如新文章的模版文件post.md
    • Front-matter:即文章开头的一些变量,常见包括文章名,日期等,可以自己添加categories以及tags方便管理

    然后再看next主题官方文档

    next官方文档将配置分类入门、主题设定、第三方服务、标签插件和高级设置等几个大类,每个大类又分为几个小类,如下:

    入门

    包括next主题安装与基本配置,next的配置文件即主题配置文件在next/_config.yml处。

    主题设定

    主要包括文字对齐、代码块样式、阅读进度和字体定制等。
    其中还有页脚与侧边栏的设置,在帖子下还有字数统计选项,也包括如何自定义界面以及SEO。

    第三方服务

    第三方包括数学公式的支持,评论系统,以及统计与分析,其中评论系统不建议采取官方文档所推荐的那些,而是使用valine系统,详情见下文。而统计与分析一个很常见的功能就是统计访问量,而valine最新版本已经支持基于leancloud的计数了,同样见下文的valine评论系统。

    至于标签插件和高级设置则看个人喜好了,下面的内容将对官方文档的说明做一个补充,并且持续更新~~。

    给本地文章md文件按年月分类

    现在hexo n 文章名会在source/_posts/下创建文件,但是如果文章太多的话放在同一个目录下不好管理,此时可以更改站点配置文件blogs/_config.yml中的new_post_name,如下

    new_post_name: :year/:month/:title.md 
    

    这样hexo n 文章名之后会在source/_posts/创建比如2020/04/文章名.md文件,即按年月分类。

    插入图片

    插入图片这个搞了我好久,首先强烈建议使用图床,常见的可以搜索Github+PigGo。然后文章中直接按如下格式即可。

    ![fig1](https://raw.githubusercontent.com/JohnJim0816/blog-figures/master/2020/4/10/1.png)
    

    插入本地图片的方式参考CSDN,注意hexo-asset-image模块的安装可能会造成文章目录中文乱码的bug,如下:

    image2

    添加站内搜索

    首先安装

    npm install hexo-generator-search --save
    

    然后站点配置文件blogs/_config.yml添加

    search:
      path: ./public/search.xml
      field: post
      format: html
      limit: 10000
    

    主题配置文件themes/next/_config.yml设置

    local_search:
      enable: true
      # If auto, trigger search by changing input.
      # If manual, trigger search by pressing enter key or search button.
      trigger: auto
      # Show top n results per article, show all results by setting to -1
      top_n_per_article: 1
    

    给网页文章增加分类和标签

    首先hexo n page categories以及hexo n page tags新建目录页和标签页,此时本地source文件夹下会生成相应的文件夹,将比如categories中的index.md更改如下:

    ---
    title: 分类
    date: 2020-04-10 21:53:23
    type: categories
    ---
    

    关键是type这一项,tags也同理,

    ---
    title: 标签
    date: 2020-04-10 21:53:46
    type: tags
    ---
    

    然后在文章开头的Front-matter部分,写上相应分类和标签,如下

    ---
    title: 我的Hexo-Github博客搭建笔记
    date: 2020-04-10 21:29:41
    categories: 野生技术
    tags: 
        - hexo
        - 笔记
    ---
    

    再到主题配置文件,即themes下的_config.yml文件,找到menu部分,配置如下:

    menu:
      home: / || home
      categories: /categories/ || th
      tags: /tags/ || tags
      archives: /archives/ || archive
    

    其中||后面指向图标的链接,如果没有则图标默认是问号。

    由此可以类推新建一个类似于标签、分类这样的菜单栏,可参考这个博客

    如何开启阅读全文

    在文章中加入<!-- more -->即可,参考官方文档

    增加阅读时间和字数统计

    首先安装hexo-symbols-count-time,

    npm i hexo-symbols-count-time --save
    

    如果之前安装了hexo-wordcount就要卸载掉npm uninstall hexo-wordcount,因为它只适用于老版本,网页也有教程是这个,
    修改站点配置文件/_config.yml,没有就添加

    symbols_count_time: 
      symbols: true
      time: true
      total_symbols: true
      total_time: true
      awl: 2
      wpm: 300
    

    其中awl(Average Word Length)的数值是设定多少字符统计为一个字(word),中文博客需要设置为 2。wpm(Words Per Minute)是你的阅读速度,多少字(word)统计为阅读时长一分钟。以下是官方文档里的一些阅读速度参考数据:

    • 慢速:200
    • 中速:275(默认)
    • 快速:350

    然后修改主题配置文件next/_config.yml

    symbols_count_time:
      separated_meta: true
      item_text_post: true
      item_text_total: true
    

    最后需要hexo clean然后重新生成,否则可能会出现阅读时间NaN字样,参考官方

    增加valine评论系统

    知乎有关于评论系统的讨论,目前我暂时使用valine评论系统。

    leancloud中进行相关的准备工作

    该评论系统依赖于leancloud,所以需要先在leancloud中进行相关的准备工作。

    • 登录 或 注册 LeanCloud

    • 登录成功后,进入后台点击左上角的创建应用:

      image3

    • 创建好应用,进入应用,左边栏找到 设置 ,然后点击 应用Key,此时记录出现的 App IDApp Key,后面配置文件中会用到

    • 因为评论和文章阅读数统计依赖于存储,所以还需要建立两个新的存储 Class,左边栏找到并点击 存储,点击 创建Class:
      image4

    • 创建两个存储Class,分别命名为: CounterComment

    • 还需要为应用添加安全域名,左边栏点击 设置,找到 安全中心,点击后会看到 安全域名 设置框,输入博客使用的域名(注意下图去掉最后一个"/"),点击保存即可:
      image5

    修改主题配置文件next/_config.yml

    找到valine部分,

    image6

    上面几项内容的含义,这里简单说明需要修改的部分,具体还是要看 Valine官网中配置相关的内容:

    参数用途
    enable 这是用于主题中配置的,不是官方Valine的参数,true时控制开启此评论系统
    appId 这是在 leancloud 后台应用中获取的,也就是上面提到的 App ID
    appKey 这是在 leancloud 后台应用中获取的,也就是上面提到的 App Key
    notify 用于控制是否开启邮件通知功能,具体参考邮件提醒配置
    verify 用于控制是否开启评论验证码功能
    avatar 用于配置评论项中用户头像样式,有多种选择:mm, identicon, monsterid, wavatar, retro, hide。详细参考:头像配置
    placehoder 评论框的提示符
    visitor 控制是否开启文章阅读数的统计功能i, 详情阅读文章阅读数统计

    开启阅读次数即将visitor值改为true之后可能会出现首页阅读次数为0而文章页面阅读次数的bug,经验表明遇到这种情况不用管它不用管它不用管它,过阵子会好的。

    完善评论通知

    Valine 评论邮件提醒功能不太健全,通知邮件中没有文章直达链接,Valine 官网中提供了评论系统第三方功能扩展Valine链接,按照链接中的说明,非常详细的步骤,一步步很容易实现完备的评论系统后台管理以及邮件提醒功能,部分高级配置点我了解。

    删除评论

    直接在leancloud后台的存储中找到之前创建的Comment这个class找到对应评论删除即可。

    image7

    参考链接

    Hexo官方文档

    知乎 - GitHub+Hexo 搭建个人网站详细教程

    b站 - 手把手教你从0开始搭建自己的个人博客

  • 相关阅读:
    Linux系统与网络服务管理技术
    RAM阵列
    5月9日上海书城PPT畅销图书作者讲座
    计算变为人们梦寐以求的公用设施
    博文视点大讲堂28期 “助你赢在软件外包行业”成功举办
    WebService WSDL详解(上)
    Google十三年
    预编译头sadafx.h原理
    WebService WSDL详解(下)
    Ext 2.2在IE 9运行居然说Extall.j运行错误,晕死了
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13281665.html
Copyright © 2020-2023  润新知