Hexo 搭建个人博客
概述
什么是 Hexo?
Hexo 是一个快速、简洁且高效的博客框架。Hexo 使用 Markdown(或其他渲染引擎)解析文章,在几秒内,即可利用靓丽的主题生成静态网页。
准备环境
NodeJs安装
从官网https://nodejs.org/en/ 下载,直接安装即可,测试一下
node -v
# v11.15.0
npm -v
# 6.7.0
npm修改源
获取npm源
npm get registry
修改npm源
npm config set registry http://registry.npm.taobao.org/
如果想重置回去
npm config set registry https://registry.npmjs.org/
安装Git
从官网https://git-scm.com/download/win 下载,直接安装即可
设置邮箱和用户名
git config --global user.name **** # 设置用户名(gitee的注册昵称)
git config --global user.email *****@**.com # 设置gitee邮箱(gitee的注册邮箱)
安装hexo
npm install -g hexo-cli
建站部署
安装 Hexo 完成后,请执行下列命令,Hexo 将会在指定文件夹中新建所需要的文件。
# 初始化博客文件夹
hexo init <folder>
# 进入博客目录
cd <folder>
# 安装
npm install
新建完成后,指定文件夹的目录如下:
.
├── _config.yml
├── package.json
├── scaffolds
├── source
| ├── _drafts
| └── _posts
└── themes
这样hexo就安装完成了,接下来就可以启动hexo
了
hexo clean # 清除所有记录
hexo generate # 生成静态网页
hexo server -p 80 # 启动服务
本地预览
# 清除所有记录
hexo clean
# 编译项目,输入命令:
hexo g
# 运行项目,输入命令:
hexo s
在浏览器地址栏输入 http://localhost:4000/ 就能看到效果啦
部署到Gitee
安装插件
npm install hexo-deployer-git --save
修改站点配置文件
# URL
url: https://gitee.com/valten/blog
root: /blog/
# Deployment
## Docs: https://hexo.io/docs/deployment.html
deploy:
type: git
repo: git@gitee.com:valten/blog.git
branch: develop
部署
hexo clean && hexo g && hexo d
进入gitee仓库,找到服务,选择Gitee Pages
选择部署分支,我这里是develop分支,然后点击更新即可
测试
浏览器地址输入 https://gitee.com/valten/blog
部署到Gihub
安装插件
npm install hexo-deployer-git --save
修改站点配置文件
# URL
url: https://valtenhyl.github.io
root: /
# Deployment
## Docs: https://hexo.io/docs/deployment.html
deploy:
type: git
repo: git@github.com:valten-hyl/valtenhyl.github.io.git
branch: deploy
部署
hexo clean && hexo g && hexo d
进入github仓库,找到项目,选择Settings,选择Pages,Source选择部署的时候的分支,点击Save按钮保存即可
测试
浏览器地址输入 https://valtenhyl.github.io
最后我还是选择了Gitee。
为什么使用Gitee而不使用GitHub
1、GitHub Pages访问龟速不稳定;
2、GitHub私有仓库收费,而Gitee私有仓库免费;
配置优化
分类和标签
定义分类页
hexo new page categories
---
title: 分类
date: 2019-12-14 10:56:27
type: "categories"
---
定义分类页
hexo new page tags
---
title: 标签
date: 2019-12-14 10:56:27
type: "tags"
---
文章添加分类和标签属性
---
title: SpringBoot+Mybatis 通过databaseIdProvider支持多数据库
date: 2019-12-14 16:42:51
tags:
- Spring Boot
- Mybatis
- databaseIdProvider
- 多数据库
categories:
- [Java,Spring Boot] # 多级标签
- Mybatis
---
修改主题配置文件,显示分类和标签菜单
# External url should start with http:// or https://
menu:
home: / || home
categories: /categories/ || th
tags: /tags/ || tags
archives: /archives/ || archive
#about: /about/ || user
#schedule: /schedule/ || calendar
#sitemap: /sitemap.xml || sitemap
#commonweal: /404/ || heartbeat
关于
hexo new page about
修改主题配置文件,显示关于
# External url should start with http:// or https://
menu:
home: / || home
categories: /categories/ || th
tags: /tags/ || tags
archives: /archives/ || archive
about: /about/ || user
#schedule: /schedule/ || calendar
#sitemap: /sitemap.xml || sitemap
#commonweal: /404/ || heartbeat
编辑about目录下的index.md。
公益404
hexo new page commonweal
修改主题配置文件,#commonweal: /404/ || heartbeat
改成commonweal: /404.html || heartbeat
。
# External url should start with http:// or https://
menu:
home: / || home
categories: /categories/ || th
tags: /tags/ || tags
archives: /archives/ || archive
about: /about/ || user
#schedule: /schedule/ || calendar
#sitemap: /sitemap.xml || sitemap
commonweal: /404.html || heartbeat
附上index.md
---
title: 404 Not Found:该页无法显示
date: 2019-12-14 17:40:17
permalink: /404
---
<!DOCTYPE html>
<html lang="zh-cn">
<head>
<meta charset="UTF-8" />
<title>404</title>
</head>
<body>
<script type="text/javascript"
src="//qzonestyle.gtimg.cn/qzone/hybrid/app/404/search_children.js"
homePageName="返回宝贝回家" homePageUrl="https://valten.gitee.io/blog">
</script>
</body>
</html>
阅读全文按钮
在文章中想要预览的文字后加<!--more-->
,这在之后的内容就会隐藏起来,点击Read More就会显示全文。
添加图片
---
title: Hello World
tags:
- Hello
- World
categories:
- Hello
photos:
- "http://q2gep6iwb.bkt.clouddn.com/blog/20191213/7Jk7p7nSUWpC.jpg"
---
文章置顶
移除默认安装的插件:
npm uninstall hexo-generator-index --save
安装新插件:
npm install hexo-generator-index-pin-top --save
最后编辑有这需求的相关文章时,在Front-matter(文件最上方以—分隔的区域)加上一行:top: true
如果你置顶了多篇,怎么控制顺序呢?设置top的值(大的在前面),比如:
# Post a.md
title: a
top: 1
# Post b.md
title: b
top: 10
文章 b 便会显示在文章 a 的前面。
添加萌宠看板娘
安装插件
npm install hexo-helper-live2d --save
安装想要的模型
npm install live2d-widget-model-shizuku --save
站点配置文件添加以下配置
# Live2D
## https://github.com/EYHN/hexo-helper-live2d
live2d:
enable: true # 开启live2d
scriptFrom: local # 默认
pluginRootPath: live2dw/ # 插件在站点上的根目录(相对路径)
pluginJsPath: lib/ # 脚本文件相对与插件根目录路径
pluginModelPath: assets/ # 模型文件相对与插件根目录路径
tagMode: false # 标签模式, 是否仅替换 live2d tag标签而非插入到所有页面中
debug: false # 调试, 是否在控制台输出日志
model:
# 选择哪种模型 https://huaji8.top/post/live2d-plugin-2.0/
# shizuku、wanko、hibiki、z16、haru、Epsilon2.1、koharu、haruto、
# npm install live2d-widget-model-wanko --save
use: live2d-widget-model-shizuku
display: #放置位置和大小
position: left
width: 150
height: 300
mobile:
show: false # 是否在手机端显示
修改站点基本信息
# Site
title: 青衫不改 # 标题
subtitle: 小白の博客 # 副标题
description: 浮生若梦,为欢几何 # 描述
keywords: 'Hexo, NexT' # 网站默认关键词
author: valten
language: en
timezone: ''
文章永久链接
修改站点配置文件
#permalink: :year/:month/:day/:title/
permalink: :category/:title/
更换主题
# 下载主题
git clone https://github.com/theme-next/hexo-theme-next.git themes/next
修改站点配置文件
# Extensions
## Plugins: https://hexo.io/plugins/
## Themes: https://hexo.io/themes/
theme: next # 值为themes目录下主题文件夹的名称
查看效果
hexo clean && hexo g && hexo s
社交链接
social:
GitHub: https://github.com/valtenhyl || github
E-Mail: mailto:valtenhyl@163.com || envelope
Weibo: https://weibo.com/3114281855 || weibo
简书: https://www.jianshu.com/u/9f816d1869d4 || book
掘金: https://juejin.im/user/5baa5f9d5188255c5d569951 || ils
#Google: https://plus.google.com/yourname || google
#Twitter: https://twitter.com/yourname || twitter
#FB Page: https://www.facebook.com/yourname || facebook
#StackOverflow: https://stackoverflow.com/yourname || stack-overflow
#YouTube: https://youtube.com/yourname || youtube
#Instagram: https://instagram.com/yourname || instagram
#Skype: skype:yourname?call|chat || skype
#RSS: /atom.xml || rss
social_icons:
enable: true # 是否在社交链接标签上显示图标
icons_only: true # 只显示图标
transition: false # 是否显示过渡效果
友情链接
# Blog rolls
links_settings:
icon: link # 链接图标
title: 友情链接 # 链接文字
# Available values: block | inline
layout: inline # 链接样式
links:
圣豪Boy: https://xshcloudy.gitee.io/blog/
BootCDN: https://www.bootcdn.cn/
易百教程: https://www.yiibai.com/
代码高亮
codeblock:
# Code Highlight theme
# Available values: normal | night | night eighties | night blue | night bright | solarized | solarized dark | galactic
# See: https://github.com/chriskempson/tomorrow-theme
highlight_theme: night
# Add copy button on codeblock
copy_button:
enable: true
# Show text copy result.
show_result: true
# Available values: default | flat | mac
style: default
图片浏览放大
cd themes/next/source/lib
git clone https://github.com/theme-next/theme-next-fancybox3 fancybox
修改主题配置文件
# FancyBox is a tool that offers a nice and elegant way to add zooming functionality for images.
# For more information: https://fancyapps.com/fancybox
fancybox: true
站点访问统计
# Show Views / Visitors of the website / page with busuanzi.
# Get more information on http://ibruce.info/2015/04/04/busuanzi
busuanzi_count: # 不蒜子统计,用于在页脚显示总访客数和总浏览量
enable: true
total_visitors: true
total_visitors_icon: user
total_views: true
total_views_icon: eye
post_views: true
post_views_icon: eye
评论系统
Valine 诞生于2017年8月7日,是一款基于Leancloud的快速、简洁且高效的无后端评论系统。
登录 Leancloud 官网,注册之后创建一个应用 ,【设置】->【应用Keys】,根据显示的内容修改主题配置文件
# Valine
# For more information: https://valine.js.org, https://github.com/xCss/Valine
valine: # 评论
enable: true
appid: jflkasjdklfjlajsdlkfklsd-sdfasdf # Your leancloud application appid
appkey: ahskfdhlkasdkfjkalsdflasdf # Your leancloud application appkey
notify: true # 评论回复邮件提醒, See: https://github.com/xCss/Valine/wiki
verify: false # 验证码服务 Verification code
placeholder: 留言区 # 留言区 Comment box placeholder
avatar: mm # 头像配置 Gravatar style
guest_info: nick,mail,link # 回复填写的信息 Custom comment header
pageSize: 10 # Pagination size
language: # Language, available values: en, zh-cn
visitor: false # Article reading statistic
comment_count: true # If false, comment count will only be displayed in post page, not in home page
recordIP: false # Whether to record the commenter IP
serverURLs: # When the custom domain name is enabled, fill it in here (it will be detected automatically by default, no need to fill in)
#post_meta_order: 0
本地搜索
npm install hexo-generator-searchdb --save
修改站点配置文件
# 本地搜索
search:
path: search.xml
field: post
format: html
limit: 10000
修改主题配置文件,开启本地搜索
# Local Search
# Dependencies: https://github.com/theme-next/hexo-generator-searchdb
local_search:
enable: true
文字数量和阅读时长
npm install hexo-symbols-count-time --save
修改主题配置文件
# Post wordcount display settings
# Dependencies: https://github.com/theme-next/hexo-symbols-count-time
symbols_count_time:
separated_meta: true
item_text_post: true
item_text_total: true
awl: 4
wpm: 275
开启RRS订阅
npm install hexo-generator-feed --save
站点配置文件添加以下配置
# RSS订阅
feed:
type: atom
path: atom.xml
limit: 20
hub:
content:
content_limit: 140
content_limit_delim: ' '
主题配置文件
# Social Links
# Usage: `Key: permalink || icon`
# Key is the link label showing to end users.
# Value before `||` delimiter is the target permalink, value after `||` delimiter is the name of Font Awesome icon.
social:
GitHub: https://github.com/valten-hyl || github
E-Mail: mailto:valtenhyl@163.com || envelope
Weibo: https://weibo.com/3114281855 || weibo
简书: https://www.jianshu.com/u/9f816d1869d4 || book
掘金: https://juejin.im/user/5baa5f9d5188255c5d569951 || ils
#Google: https://plus.google.com/yourname || google
#Twitter: https://twitter.com/yourname || twitter
#FB Page: https://www.facebook.com/yourname || facebook
#StackOverflow: https://stackoverflow.com/yourname || stack-overflow
#YouTube: https://youtube.com/yourname || youtube
#Instagram: https://instagram.com/yourname || instagram
#Skype: skype:yourname?call|chat || skype
RSS: /atom.xml || rss
标签云配色
# TagCloud settings for tags page.
tagcloud:
# All values below are same as default, change them by yourself.
min: 12 # Minimun font size in px
max: 31 # Maxium font size in px
start: "#381096" # Start color (hex, rgba, hsla or color keywords)
end: "#922a4b" # End color (hex, rgba, hsla or color keywords)
amount: 200 # Amount of tags, change it if you have more than 200 tags
禁止页面评论
在不需要评论的页面或者文章Front-matter(文件最上方以—分隔的区域)加上comments: false
---
title: categories
date: 2019-12-14 17:22:21
type: "categories"
comments: false
---
AddThis分享
首先在AddThis官网注册账号,选择并配置分享按钮,激活,获取pubid
,修改主题配置文件
# AddThis Share. See: https://www.addthis.com
# Go to https://www.addthis.com/dashboard to customize your tools.
add_this_id: ra-2341234445555
Fork me on GitHub
修改主题配置文件
# `Follow me on GitHub` banner in the top-right corner.
github_banner:
enable: true
permalink: https://github.com/valten-hyl
title: Follow me on GitHub
隐藏强力驱动和主题信息
powered:
# Hexo link (Powered by Hexo).
enable: false
# Version info of Hexo after Hexo link (vX.X.X).
version: false
theme:
# Theme & scheme info link (Theme - NexT.scheme).
enable: false
# Version info of NexT after scheme info (vX.X.X).
version: false
在线聊天
首先到DaoVoice上注册一个账号,注册完成后会得到一个app_id,修改主题配置文件
# DaoVoice
# Online contact
daovoice: true
daovoice_app_id: 123sfa # 这里填你刚才获得的 app_id
打开themes/next/layout/_partials/head/head.swig
,在文件中添加
{% if theme.daovoice %}
<script>
(function(i,s,o,g,r,a,m){i["DaoVoiceObject"]=r;i[r]=i[r]||function(){(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;a.charset="utf-8";m.parentNode.insertBefore(a,m)})(window,document,"script",('https:' == document.location.protocol ? 'https:' : 'http:') + "//widget.daovoice.io/widget/e30c3408.js","daovoice")
daovoice('init', {
app_id: "{{ theme.daovoice_app_id }}"
});
daovoice('update');
</script>
{% endif %}
嵌入歌单
新建歌单页面
---
title: palylist
date: 2019-12-15 01:04:41
type: "playlist"
comments: false
---
安装播放器
npm install hexo-tag-aplayer --save
修改站点配置文件
其中id是歌单生成的外链的id
# metingjs
metingjs:
server: netease
id: 3111577471 # 歌单id 8537501
type: playlist
theme: '#2980b9'
loop: all
autoplay: false
order: random
修改模板
打开themes/next/layout/page.swig
,在文件中加入以下代码
{% elif page.type === 'playlist' %}
{{ page.content }}
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/aplayer/dist/APlayer.min.css">
<script src="https://cdn.jsdelivr.net/npm/aplayer/dist/APlayer.min.js"></script>
<!-- require MetingJS -->
<script src="https://cdn.jsdelivr.net/npm/meting@2/dist/Meting.min.js"></script>
<meting-js style="margin-top: 1.5rem; width: auto; height: auto;" server="{{ config.metingjs.server }}" type="{{ config.metingjs.type }}" id="{{ config.metingjs.id }}" theme="{{ config.metingjs.theme }}" loop="{{ config.metingjs.loop }}" autoplay="{{ config.metingjs.autoplay }}" order="{{ config.metingjs.order }}" storageName="aplayer-setting" lrctype=0 />
{% elif page.type === 'schedule' %}
动态标签云
安装插件
npm install hexo-tag-cloud --save
修改站点配置文件
# hexo-tag-cloud
tag_cloud:
textFont: Trebuchet MS, Helvetica
textColor: '#192e4d'
textHeight: 25
outlineColor: '#5f7a74'
maxSpeed: 0.5 # [0.01, 1]
修改页面模板
打开themes/next/layout/page.swig
,找到class="tag-cloud"
,在里面添加以下代码
# hexo-tag-cloud
tag_cloud:
textFont: Trebuchet MS, Helvetica
textColor: '#192e4d'
textHeight: 25
outlineColor: '#5f7a74'
maxSpeed: 0.5 # [0.01, 1]
添加背景图片
打开themes/next/source/css/_common/scaffolding/base.styl
body {
background: $body-bg-color;
color: $text-color;
font-family: $font-family-base;
font-size: $font-size-base;
line-height: $line-height-base;
// 背景图片
background: url(http://q2gep6iwb.bkt.clouddn.com/blog/20191215/s6j9RkCgHaW4.jpg);
background-size: cover;
background-repeat: no-repeat;
background-attachment: fixed;
background-position: 50% 50%;
+tablet-mobile() {
// Remove the padding of body when the sidebar is open.
padding-left: 0 !important;
padding-right: 0 !important;
}
}
// 修改主体透明度
.main-inner {
background: #0a1627;
opacity: 0.9;
}
// 修改菜单栏透明度
.header-inner {
opacity: 0.8;
}
动态背景
cd themes/next
git clone https://github.com/theme-next/theme-next-canvas-nest source/lib/canvas-nest
修改主题配置文件
# Canvas-nest
# Dependencies: https://github.com/theme-next/theme-next-canvas-nest
# For more information: https://github.com/hustcc/canvas-nest.js
canvas_nest:
enable: true
onmobile: true # Display on mobile or not
color: "0,0,255" # RGB values, use `,` to separate
opacity: 0.5 # The opacity of line: 0~1
zIndex: -1 # z-index property of the background
count: 99 # The number of lines
加载进度条
修改主题配置文件,开启进度条,选择进度条样式
# Progress bar in the top during page loading.
# Dependencies: https://github.com/theme-next/theme-next-pace
# For more information: https://github.com/HubSpot/pace
pace:
enable: true
# Themes list:
# big-counter | bounce | barber-shop | center-atom | center-circle | center-radar | center-simple
# corner-indicator | fill-left | flat-top | flash | loading-bar | mac-osx | material | minimal
theme: pace-theme-bounce #选择进度条样式
修改主题配置文件,引入对应的js和css
vendors:
pace: //cdn.bootcss.com/pace/1.0.2/pace.min.js
pace_css: //cdn.bootcss.com/pace/1.0.2/themes/black/pace-theme-bounce.min.css
回到顶部样式
修改主题配置文件,开启回到顶部
back2top:
enable: true
# Back to top in sidebar.
sidebar: false
# Scroll percent label in b2t button.
scrollpercent: false
# 钢铁侠
ironman: true
在themes/next/source/js
下新建totop.js
$(window).scroll(function() {
$(window).scrollTop() > $(window).height()*0.5 ? $("#rocket").addClass("show") : $("#rocket").removeClass("show");
});
$("#rocket").click(function() {
$("#rocket").addClass("launch");
$("html, body").animate({
scrollTop: 0
}, 1000, function() {
$("#rocket").removeClass("show launch");
});
return false;
});
修改themes/next/layout/_partials/wigets.swig
{%- if theme.back2top.enable and not theme.back2top.sidebar %}
{%- if theme.back2top.ironman %}
<span id="rocket" href="#top" class=""></span>
<script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
{{- next_js('totop.js') }}
{%- else %}
<div class="back-to-top motion-element">
<i class="fa fa-arrow-up"></i>
<span>0%</span>
</div>
{%- endif %}
{%- endif %}
修改themes/next/source/css/common/scaffolding
下的base.styl
// 钢铁侠
#rocket {
position: fixed;
right: 50px;
bottom: 50px;
z-index: 3;
display: block;
visibility: hidden;
width: 42px;
height: 43px;
background: url("https://s2.ax1x.com/2019/12/16/Q51U0O.png") no-repeat 50% 0;
opacity: 0;
cursor: pointer;
-webkit-transition: visibility 0.6s cubic-bezier(0.6, 0.04, 0.98, 0.335), opacity 0.6s cubic-bezier(0.6, 0.04, 0.98, 0.335), -webkit-transform 0.6s cubic-bezier(0.6, 0.04, 0.98, 0.335);
-moz-transition: visibility 0.6s cubic-bezier(0.6, 0.04, 0.98, 0.335), opacity 0.6s cubic-bezier(0.6, 0.04, 0.98, 0.335), -moz-transform 0.6s cubic-bezier(0.6, 0.04, 0.98, 0.335);
transition: visibility 0.6s cubic-bezier(0.6, 0.04, 0.98, 0.335), opacity 0.6s cubic-bezier(0.6, 0.04, 0.98, 0.335), transform 0.6s cubic-bezier(0.6, 0.04, 0.98, 0.335);
}
#rocket i {
display: block;
margin-top: 48px;
height: 14px;
background: url("https://s2.ax1x.com/2019/12/16/Q51U0O.png") no-repeat 50% -20px;
opacity: .5;
-webkit-transition: -webkit-transform .2s;
-moz-transition: -moz-transform .2s;
transition: transform .2s;
-webkit-transform-origin: 50% 0;
-moz-transform-origin: 50% 0;
transform-origin: 50% 0;
}
#rocket:hover {
background-position: 50% -44px;
}
#rocket:hover i {
background-position: 50% 100%;
-webkit-animation: flaming .7s infinite;
-moz-animation: flaming .7s infinite;
animation: flaming .7s infinite;
}
#rocket.show {
visibility: visible;
opacity: 1;
}
#rocket.launch {
background-position: 50% -44px;
opacity: 0;
-webkit-transform: translateY(-500px);
-moz-transform: translateY(-500px);
-ms-transform: translateY(-500px);
transform: translateY(-500px);
pointer-events: none;
}
#rocket.launch i {
background-position: 50% 100%;
-webkit-transform: scale(1.4, 3.2);
-moz-transform: scale(1.4, 3.2);
transform: scale(1.4, 3.2);
}
命令
常用命令:
hexo new "postName" # 新建文章
hexo new page "pageName" # 新建页面
hexo generate # 生成静态页面至public目录
hexo server # 开启预览访问端口(默认端口4000,'ctrl + c'关闭server)
hexo deploy # 将.deploy目录部署到GitHub
常用复合命令:
hexo d -g
hexo s -g
hexo clean && hexo g && hexo s
hexo clean && hexo g && hexo d
简写:
hexo n == hexo new
hexo g == hexo generate
hexo s == hexo server
hexo d == hexo deploy
博客地址:http://valten.gitee.io/blog
参考:
https://www.jianshu.com/p/6f77c96b7eff
https://blog.csdn.net/u012294515/article/details/83094693
https://blog.csdn.net/loze/article/details/94206726
https://github.com/huweihuang/huweihuang.github.io