Fork me on GitHub

如何利用Github搭建个人博客

注:

1
2
Hexo是一个快速、简洁且高效的博客框架。 
Hexo使用Markdown解析文章,在几秒内,即可利用靓丽的主题(如NexT)生成静态网页。

** 特别推荐 **

Ⅰ: 搭建指南:

1. Hexo 博客搭建指南

2. 【Hexo搭建独立博客全纪录】(三)使用Hexo搭建博客

Ⅱ: 添加评论功能:

3. hexo - Next 主题添加评论功能

4. Next主题增加Gitment评论系统

5. 添加Gitment评论系统踩过的坑

6. Gitment评论功能接入踩坑教程

Ⅲ: 主题优化:

7. hexo的next主题个性化教程:打造炫酷网站

Ⅳ: 博客源备份:

8. GitHub + Hexo搭建自己博客(三) 多设备管理


** 正文 **

一、基础搭建

1. 注意事项:

每次新增或更新博客时,要注意执行以下命令:

1
2
3
$ hexo clean	//清除缓存文件db.json和已生成的静态文件public
$ hexo g //生成网站静态文件到默认设置的public文件夹
$ hexo d //部署网站到设定的仓库

或把后两条命令合二为一:

1
2
$ hexo clean	//清除缓存文件db.json和已生成的静态文件public
$ hexo d -g //生成并上传
  1. Hexo博客搭建全攻略
  2. 【Hexo搭建独立博客全纪录】(三)使用Hexo搭建博客
  3. Hexo(2)-部署博客及更新博文
  4. Hexo博客的搭建及同步更新
  5. 如何快速搭建自己的github.io博客
  6. 持续更新】最全Hexo博客搭建+主题优化+插件配置+常用操作+错误分析
  7. 免费个人博客搭建详解
  8. Hexo搭建博客教程

2. 搭建过程中遇到的问题:

  1. 解决用Hexo和GitHub搭建博客时hexo d命令报错问题
  2. 将本地 Hexo 仓库部署到 GitHub 上
  3. V.GitHub + Hexo (2):部署博客及更新博文

3. 博客模板推荐:

  1. 使用hexo+github搭建免费个人博客详细教程
  2. 博客搭建详细教程
  3. Github搭建个人博客(2019最新版,亲测)
  4. jekyll框架
  5. hexo框架
  6. hexo-theme-next——Elegant theme for Hexo.
  7. hexo-theme-yilia——一个简洁优雅的hexo主题
  8. hexo-theme-matery——一个Hexo主题
  9. 模板博客

4. 大神博客推荐:

  1. 韦阳的博客
  2. 超详细Hexo+Github博客搭建小白教程——韦阳博客
  3. 超详细Hexo+Github博客搭建小白教程——知乎

二、Gitment:使用 GitHub Issues 搭建评论系统

  1. Gitment:使用 GitHub Issues 搭建评论系统
  2. 使用hexo搭建github博客
  3. hexo - Next 主题添加评论功能
  4. gitment——Github官网

三、搭建评论系统时遇到的问题汇总

1. 添加评论时出现”[object ProgressEvent] “问题:

object ProgressEvent问题解决:
找到next主题中的gitment评论文件 next/layout/_third-party/comments/gitment.swig,更改以下代码:

1
2
3
4
5
6
7
8
9
10
<!-- 原代码 -->
// gitment的英文版
<link rel="stylesheet" href="https://imsun.github.io/gitment/style/default.css">
<script src="https://imsun.github.io/gitment/dist/gitment.browser.js"></script>

// gitment的汉化版
// 只需到模板里将原来定义CSS和JS的那两行改成:
<!-- 请使用下面的替换 2019-06-30更新-->
<link rel="stylesheet" href="https://billts.site/extra_css/gitment.css">
<script src="https://billts.site/js/gitment.js"></script>

完整代码如下:

1
2
3
4
5
6
7
8
9
10
11
<!-- LOCAL: You can save these files to your site and update links -->
{% if theme.gitment.mint %}
{% set CommentsClass = "Gitmint" %}
<link rel="stylesheet" href="https://aimingoo.github.io/gitmint/style/default.css">
<script src="https://aimingoo.github.io/gitmint/dist/gitmint.browser.js"></script>
{% else %}
{% set CommentsClass = "Gitment" %}
<link rel="stylesheet" href="https://billts.site/extra_css/gitment.css">
<script src="https://billts.site/js/gitment.js"></script>
{% endif %}
<!-- END LOCAL -->

重新清理缓存,部署博客即可留言。

  1. Next主题增加Gitment评论系统
  2. [object ProgressEvent] #170
  3. gitment评论模块接入hexo | 我的博客 #8
  4. hexo博客配置-添加评论系统-gitment和valine-需注册
  5. gitment评论模块接入hexo
  6. hexo博客的gitment评论开启一直失败 #178
  7. GitHub Pages个人博客搭建流程

    2. 使用Gitment遇到的问题: Error:validation failed

    在这里插入图片描述
1
2
3
4
// 原配置
id: '<%= page.title %>'
// 修改后的配置
id: '<%= page.date %>'
  1. Gitment评论功能接入踩坑教程
  2. 添加Gitment评论系统踩过的坑
  3. 使用Gitment遇到的问题: Error:validation failed
  4. Hexo+gitment的Error:validation failed
  5. gitalk Error: Validation Failed
  6. Hexo添加gitalk评论插件及 Error: Validation Failed 报错解决
  7. 处理Gitalk中由于文章URL过长导致的Validation Failed(422)
  8. 所有文章一键初始化评论 #5
  9. JavaScript-MD5
  10. issue的Label有长度限制!把id留空可能导致 Error: Validation Failed #112
  11. Error: Validation Failed #118
  12. 报错出现 Error: Validation Failed. #102

四、Hexo的Next主题详细配置

1. 整体配置:

  1. hexo的next主题个性化教程:打造炫酷网站
  2. hexo的next主题个性化配置教程
  3. 超详细Hexo+Github博客搭建小白教程
  4. Hexo的Next主题详细配置
  5. 开始使用
  6. 主题配置
  7. hexo+next 部署各种炫酷博客特效
  8. 2018 - Hexo - Next - Mist 风格主题的美化(二)
  9. 你见过的最棒的个人博客界面是什么样的?
  10. 【12】2小时还你一个集打赏、评论、RSS功能于一身的个人博客
  11. Hexo+Next主题优化
  12. HEXO+NEXT主题个性化配置
  13. 对NexT主题风格的修改
  14. Hexo-NexT配置超炫网页效果
  15. hexo指南
  16. 使用next主题配置博客基本信息
  17. NexT的主题设定与配置
  18. Github+Hexo一站式部署个人博客 (原创)
  19. 使用Hexo+Github一步步搭建属于自己的博客(进阶)
  20. hexo next主题优化,打造个人精致网站
  21. hexo的next主题个性化配置
  22. Hexo+Next个人博客主题优化
  23. GitHub + Hexo搭建自己博客(二) Next主题配置

    2. 局部配置:

  24. Hexo博客NexT主题美化之顶部加载进度条
  25. Hexo Next 添加萌萌的宠物live2d
  26. Hexo博客添加在线联系功能
  27. hexo next 配置 DaoVoice 实现在线聊天功能
  28. DaoVoice控制台
  29. 设置文章打赏
  30. Hexo NexT主题添加点击爱心效果
  31. Hexo之在右上角或者左上角实现fork me on github
  32. Hexo + Next 的优化
  33. Hexo Next 主题中添加本地搜索功能
  34. 为 Hexo 博客创建本地搜索引擎
  35. hexo博文压缩
  36. Next主题美化(持续更新)
  37. Hexo NexT主题中添加网页标题崩溃欺骗搞怪特效
  38. 动态title-网站标题崩溃欺骗

五、GitHub + Hexo搭建自己博客:备份博客源文件

  1. GitHub + Hexo搭建自己博客(三) 多设备管理
  2. 超详细Hexo+Github博客搭建小白教程

在这里插入图片描述
在这里插入图片描述

六、Hexo + Next 主题博客添加分享功能

首先在themes\next\layout\_partials\share中新建一个文件socialshare.swig,
编辑内容如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<script src="../lib/jquery/index.js"></script>
<link href="https://cdn.bootcss.com/social-share.js/1.0.16/css/share.min.css" rel="stylesheet">
<script src="https://cdn.bootcss.com/social-share.js/1.0.16/js/jquery.share.min.js"></script>

<script> var $config = {
url : window.location.href,// 网址,默认使用 window.location.href
source : '', // 来源(QQ空间会用到), 默认读取head标签:<meta name="site" content="http://overtrue" />
title : '', // 标题,默认读取 document.title 或者 <meta name="title" content="share.js" />
description : '', // 描述, 默认读取head标签:<meta name="description" content="PHP弱类型的实现原理分析" />
image : '', // 图片, 默认取网页中第一个img标签
sites : ['qzone', 'qq', 'weibo','wechat'], // 启用的站点
disabled : ['google', 'facebook', 'twitter'], // 禁用的站点
wechatQrcodeTitle : '微信扫一扫:分享', // 微信二维码提示文字
wechatQrcodeHelper : '<p>微信里点“发现”,扫一下</p><p>二维码便可将本文分享至朋友圈。</p>',
target : '_blank' //打开方式
};
$('.social-share').share($config);
</script>

然后找到themes\next\layout_macro中的文件post.swig中的这部分代码

1
<footer class="post-footer">

之前贴上以下代码

1
2
3
4
{% if theme.social_share and not is_index %}
{% include '../_partials/share/socialshare.swig' %}
<div class="social-share"></div>
{% endif %}

在主题配置文件, _config.yml 文件中增加以下代码

1
2
social_share:
enable: true

保存修改后,然后 hexo clean ,hexo g ,hexo d 即可看到点击效果。

参考

  1. hexo 调用share.js
  2. Hexo + Next 主题博客分享功能
  3. 基于Hexo搭建个人博客——进阶篇(从入门到入土)
  4. 个性化hexo博客,添加评论系统,分享,友情链接功能
  5. Mob开发者后台使用指南
  6. ShareSDK-for-iOS
  7. Hexo博客添加分享功能
  8. hexo next主题为博客添加分享功能
  9. hexo next主题为博客添加分享功能
  10. Hexo添加分享功能
  11. hexo+next博客进阶攻略
  12. Hexo NexT主题中添加百度分享功能
  13. 百度分享不支持Https的解决方案
  14. Hexo博客NexT主题添加百度分享
  15. Hexo+Github搭建个人博客(二)——配置&主题
  16. Hexo+Github搭建个人博客(三)——百度分享集成

七、Hexo博客 站内搜索 配置 (swiftype)

前言

随着博客的文章增多,添加一个博客站内搜索的功能就显得很有必要。

而第三方站内搜索的插件有:

  • google自定义搜索(免费的标准版貌似有广告而且要科学上网)

  • 百度站内搜索(貌似不支持https并且只显示收录的页面)

  • swiftype站内搜索(我的选择)

swiftype网站配置

  • 首先注册swiftype账号并登录,也可直接使用google账号登录

  • 然后选择CREATE A NEW ENGINE,再进行填入网址等一系列操作,设置默认就好

  • 得到左边为各项设置的搜索引擎界面

这里写图片描述

  • 点击install search,进入安装代码界面,并将这段代码复制

安装代码

  • 点击change configuration,可以看到左边有设置选项

设置选项

  • 特别注意,search field选项

如果博客本身就有搜索框,那么修改搜索框的classst-default-search-input就好了
但是如果没有,则可以自行添加搜索框,并修改class;或者选择swiftype提供的搜索框即可
由于我的博客(random主题)本身没有搜索框,所以直接选择了swiftype提供的搜索框

显示效果

  • 同时,可以在左侧的设置选项中查看搜索统计情况预览搜索结果设置搜索权重添加域名查看抓取的页面

  • 注意:swiftype的爬虫抓取页面需要一定的时间,所以可能需要等一会

  • 到此为止,swiftype网站的配置就完成了

博客的配置

  • 打开博客主题的配置文件_config.yml,在最后添加
    # swiftype站内搜索
    swift_search:
      enable: true
  • 1
  • 2
  • 3
  • 打开博客主题的themes\next\layout\_partials文件夹,在其中找到footer.swig文件(或者其他以footer命名的文件),把之前复制的脚本代码粘贴到其中

  • 注意:要放在body标签

  • 至此,博客站内搜索的工作就做完了,然后重新将博客deploy即可

  • 搜索效果

搜索效果

原文地址

在这里插入图片描述

参考

  1. Hexo博客 站内搜索 配置 (swiftype)
  2. hexo干货系列:(五)hexo添加站内搜索
  3. 如何在个人博客引擎 Hexo 中添加 Swiftype 搜索组件
  4. 如何在 Hexo 博客引擎中添加 Swiftype 搜索组件
  5. Install Site Search
-------------本文结束感谢您的阅读-------------

本文标题:如何利用Github搭建个人博客

文章作者:Zhang Yexing

发布时间:2019年08月28日 - 17:23

最后更新:2019年08月28日 - 17:24

原始链接:https://zyxzyxzyx.github.io/2019/08/28/如何利用Github搭建个人博客/

许可协议: 署名-非商业性使用-禁止演绎 4.0 国际 转载请保留原文链接及作者。

坚持原创技术分享,您的支持将鼓励我继续创作!
0%