参考资料:
1. Hexo使用
1.1. 页面配置
hexo文件夹下的配置文件_config.yml
为整个hexo的配置文件。首先第一段属性主要用于配置网站的整体信息,description和keywords用于SEO搜索引擎优化,可以暂时不管。
属性 | 描述 |
---|---|
title | 网站标题 |
subtitle | 网站副标题 |
description | 网站描述 |
keywords | 网站关键词 |
author | 网站作者 |
language | 网站使用的语言(中文为zh-CN) |
timezone | 网站时区,默认为电脑时区 |
第二部分的配置有关网站的写作布局格式以及资源链接功能
1 | # Writing |
1.2. Hexo常用命令
常用命令
1 | hexo new "postName" #新建文章 |
常用命令缩写
1 | hexo n == hexo new |
组合命令
1 | hexo s -g #生成并本地预览 |
1.3. 新建页面
执行hexo new '文章名'
,hexo会帮我们在..\hexo\source\_posts
下生成相关markdown文件,打开该文件就可以开始编辑博客了
其中的文件头有以下含义,注意每个属性冒号后都有空格
1 | title: #文章名 |
使用hexo g
命令后,该markdown文件会在public文件夹中自动生成对应的html文件,之后会自动加入文章列表
1.4. 页面模板
在hexo根目录下有scaffold文件夹。Hexo会根据scaffold中的markdown文件为模板来新建文章。使用hexo new 文章名
命令时,默认按照post.md为模板
1 | --- |
例如,我想要默认生成的文件中加入categories这个属性,可以把这个模板改为
1 | --- |
同理,可以创建多个不同模板,使用hexo new 模板名称 文章名
来调用不同模板
1.5. 插入图片
1.5.1. 我的做法
- 首先,在hexo的
_config.yml
中将post_asset_folder
设为true。这样每次创建新文章,hexo都会在source的post文件夹中创建同名的资源文件夹,用于存放图片等资源 - 在hexo根目录执行
npm install hexo-asset-image --save
,安装图片地址转换的插件 - 使用
hexo new XXX
生成文章时,在source/_posts
中放入需要插入的图片 - 在文章的markdown文件中使用如下格式插入图片:
1
![你想输入的替代文字](xxxx/图片名.jpg)
- 检查生成的网页中是否成功
1.5.2. 官方文档做法
官网链接:https://hexo.io/zh-cn/docs/asset-folders.html
通过常规的 markdown 语法和相对路径来引用图片和其它资源可能会导致它们在存档页或者主页上显示不正确。在Hexo 2时代,社区创建了很多插件来解决这个问题。但是,随着Hexo 3 的发布,许多新的标签插件被加入到了核心代码中。这使得你可以更简单地在文章中引用你的资源。
1 | {% asset_path slug %} |
比如说:当你打开文章资源文件夹功能后,你把一个 example.jpg 图片放在了你的资源文件夹中,如果通过使用相对路径的常规 markdown 语法 ,它将 不会 出现在首页上。(但是它会在文章中按你期待的方式工作)
正确的引用图片方式是使用下列的标签插件而不是 markdown :
1 | {% asset_img example.jpg This is an example image %} |
通过这种方式,图片将会同时出现在文章和主页以及归档页中。
官方的做法需要在markdown文档中插入html标签,我个人认为这种方式并不好。所以我没有选择官方做法,而是继续采取markdown语句来插入。如果未来遇到无法插入的问题,会再尝试官方方法。
2. Next主题
现在,你学会了Hexo的基本操作,但是你可能还觉得你的网站不够好看。怎么办呢?我们可以在github上寻找主题来美化我们的网站。
这里我使用的是github使用排名第一的Next主题。
2.1. Next主题的安装
2.1.1. 下载
这里直接从github下载最新版本。如果这种方法不行,可以考虑下载release page中的zip解压到对应目录
1 | $ cd hexo |
2.1.2. 启用
在hexo目录下的_config.yml
中,将theme
字段的值改为next
。这样Hexo会直接调用themes文件夹下的next主题包
接着使用hexo clean
清除缓存,使用hexo g
重新编译。可以看到主题已经生效,能够显示最基本的helloworld页面了
2.2. Next配置
2.2.1. 主题设置
Next提供了4个默认主题,在themes/next/_config.yml`中搜索scheme关键字,可以看到如何配置。这里我选用了Pisces主题
1 | # --------------------------------------------------------------- |
- Muse:默认 Scheme,这是 NexT 最初的版本,黑白主调,大量留白
- Mist:Muse 的紧凑版本,整洁有序的单栏外观
- Pisces:双栏 Scheme,小家碧玉似的清新
- Gemini:左侧网站信息及目录,块+片段结构布局
2.2.2. 动态背景
你经常在别人博客上看到并眼馋的动态背景!就是这个。
在themes/next/_config.yml
中搜索canvas关键字,可以看到如下代码
1 | # Canvas-nest |
设置为true则开启动态背景。在具体属性中可以设置线条的样式。建议将count减少,防止低配置电脑打开的卡顿。同时还提供了3种3D动态背景,喜欢的可以自己尝试
2.2.3. 当前浏览进度
修改themes/next/_config.yml
, scrollpercent
值由 false 改为 true:
1 | # Scroll percent label in b2t button |
2.2.4. 文章“分类”与“标签”的设置
使用hexo new page categories
建立categories,其中自动生成了index.md
,修改为:
1 | --- |
对tags也进行同样操作,这样在Next主题的主页下就能进入“分类”和“标签”页面了。之后的内容会自动生成,可以不用管
2.2.5. “About”页面设置
同理,使用hexo new page about
来生成about页面,在index.md中可以编辑个人相关信息。
2.2.6. 字数统计功能
参考页面https://github.com/theme-next/hexo-symbols-count-time
新版本的Next主题中,插件重新整合,因此使用了新api。这里直接使用新api来进行字数统计
- 安装
1
$ npm install hexo-symbols-count-time --save
- 在hexo根目录下的
_config.yml
中,添加如下代码来启用word count功能。1
2
3
4
5
6symbols_count_time:
symbols: true
time: true
total_symbols: true
total_time: true
exclude_codeblock: false - 在Next主题中寻找相关代码进行配置 其中,
1
2
3
4
5
6
7symbols_count_time:
separated_meta: true
item_text_post: true
item_text_total: false
awl: 2
wpm: 275
suffix: mins.awl
和wpm
的值请参阅官方文档进行配置。
如果页面中字数统计的文字出现了乱码,请打开theme/next/languages
文件夹对自己选用的语言进行查看并debug
3. 最后的话
Next还有许多优化手段,这里就不一一写出(其实我也不会)。大家有兴趣的可以自己再去研究