hexo-arknights
hexo-theme-arknights
预览
- Dr.Ye: https://laurenfrost.github.io/
- Dr.Yue_plus: http://arknights.theme.hexo.yue.zone/
- Dr.ToUNVRSe https://tounvrse.github.io/
- Dr.LingYun: https://dr-lingyun.gitee.io/
- Dr.XIMU:http://b.ligzs.cn/
- Dr.tyqtyq https://tyq0712.github.io/
- Dr.TTsdzb https://ark.ttsdzb.monster/
- Dr.Angine https://angine.tech/
- Dr.sjfhsjfh https://sjfh.top/
- Dr.Voilone https://note.voiblog.top/
- Zhongye1 https://zhongye1.github.io/
- Dr.yuanli-LFSW https://blog.yuanli-lfsw.com/
- Dr.Rimrose: https://blog.rimrose.site
如果使用了这个主题,欢迎在这儿贴预览链接~
安装
环境
-
最新版 Hexo
Hexo
6.0.0
以上; hexo-cli4.3.0
以上; -
中国大陆用户推荐使用
cnpm
安装依赖包,参考 中国 NPM 镜像
使用 hexo-cli
新建博客项目:
1 | hexo init Hexo |
安装依赖
npm 用户:
1 | cnpm install hexo-server hexo-browsersync hexo-renderer-pug --save |
yarn 用户:
1 | yarn add hexo-server hexo-browsersync hexo-renderer-pug |
修改配置文件
-
参照 Hexo 官网 修改
Hexo/
目录下的_config.yml
。-
将
theme:
的默认值landscape
改为arknights
-
开启代码高亮:
1
2highlight:
hljs: true
-
-
剪切
Hexo/themes/arknights/_config.yml
到Hexo
目录下,并重命名为_config.arknights.yml
。建议参考:
主题的配置文件可参照中文注释修改。
修改资源文件
可按需在 Hexo/source/
目录添加以下文件:
CNAME
: GitHub Pages 部署时的自定义域名img/
目录下的Alipay.png
与WeChat.png
为自己的收款二维码(1:1 比例的png
图片);
可按需修改 Hexo/themes/arknights/source/
目录下的:
favicon.ico
:浏览器标签页上的图标(64*64,分辨率高了显示不出)README.md
: 部署仓库的 README
写作
-
参考 写作 | Hexo。
-
在主题仓库的 Hexo 分支有一些 示例文本 可以取用
-
添加文章标签与分类,更多特性可参考 Hexo | Front-matter ,示例:
1
2
3
4
5
6
title: 'Hello World !'
date: 2020-04-15 21:54:02
tags: code
category: Example -
在
<!-- more -->
之前的内容称之为摘要,会显示在首页上,并且可以设置是否也在正文显示。
在导航栏中添加页面
-
例如:新建一个
about
页面- 在
Hexo
目录下执行hexo new page 'about'
- 然后
Hexo/source/
目录下会多一个about
文件夹
- 在
-
编辑
Hexo/source/about/index.md
文件 -
编辑
_config.arknights.yml
,添加一个链接:1
2menu:
About: /about
禁止归档页翻页
该设置位于 Hexo 配置文件 _config.yml
约第 88 行。
1 | # Pagination |
将 per_page:
改为 0 即可。
评论系统
Valine
本主题支持Valine 。 请参考 Valine 快速开始 修改 Hexo 目录下的 _config.arknights.yml
文件:
1 | valine: |
开启邮件提醒:zhaojun1998 / Valine-Admin
注意! 当 Valine 使用 LeanCloud 国际版 时,才需要配置
server_url:
。
该设置可在 LeanCloud 应用中的设置 -> 应用凭证 -> 域名白名单 -> Request 域名
中找到以.api.lncldglobal.com
结尾的域名,加上https://
前缀即可。
Gitalk
本主题支持 Gitalk 。 请参考 gitalk/readme-cn.md 修改 Hexo 目录下的 _config.arknights.yml
文件:
1 | gitalk: |
Waline
本主题支持 Waline 。
请参考 Waline 官方文档 修改 Hexo 目录下的 _config.arknights.yml
文件:
1 | waline: |
Artalk
本主题支持 Artalk 。
请参考 Artalk 官方文档修改 Hexo 目录下的 _config.arknights.yml
文件:
1 | artalk: |
数学公式
本主题支持两种方案显示数学公式:
方案一:静态渲染
可以使用 hexo-filter-mathjax Hexo 过滤器静态渲染,来显示数学公式。
建议先更换能更好处理数学公式的 markdown 渲染器 hexo-renderer-pandoc。
-
在 Hexo 目录下执行以下指令:
1
2
3
4# 安装 hexo-filter-mathjax 插件
cnpm install hexo-filter-mathjax --save
# 清除缓存
hexo clean -
把以下内容添加到
Hexo/_config.yml
文件:1
2
3
4
5
6
7mathjax:
tags: none # 或 'ams' 或 'all'
single_dollars: true # 启用单个美元符号作为内联(行内)数学公式定界符
cjk_width: 0.9 # 相对 CJK 字符宽度
normal_width: 0.6 # 相对正常(等宽)宽度
append_css: true # 将 CSS 添加到每个页面
every_page: false # 如果为 true,那么无论每篇文章的前题中的 `mathjax` 设置如何,每页都将由 mathjax 呈现 -
在需要启用 mathjax 的文章的 Front-matter 区内添加
mathjax: true
:1
2
3
4
5
6
title: On the Electrodynamics of Moving Bodies
categories: Physics
date: 1905-06-30 12:00:00
mathjax: true然后,就可以在文章中使用 LaTeX 语法。
-
需要注意,内联数学公式(……
$<数学公式>$
……)在开头$
之后和结尾$
之前不能有空格!例如:1
2
3
4- $ \epsilon_0 $
+ $\epsilon_0$
- $ \frac{\partial}{\partial t} $
+ $\frac{\partial}{\partial t}$ -
需要注意 LaTeX 与 Markdown 语法之间的冲突。如有必要,请使用
\
进行转义:1
2
3
4- $\epsilon_0$
+ $\epsilon\_0$
- \begin{eqnarray*}
+ \begin{eqnarray\*}
方案二:动态渲染
本主题也支持 MathJax ,在用户浏览时动态渲染公式:
-
首先要卸载 Hexo 默认自带的 hexo-renderer-marked 渲染器,更换成对 MathJax 支持更好的 hexo-renderer-kramed 渲染器:
1
2npm uninstall hexo-renderer-marked --save
npm install hexo-renderer-kramed --save -
修改 Hexo 目录 下的
_config.arknights.yml
文件:1
2
3
4
5# 公式支持
mathjax:
- enable: false
+ enable: true
version: '2.6.1' # 重要 -
然后,就可以在文章中使用 LaTeX 语法:
1
2
3
4
5
6
7
8
9% 单行内联公式
% 注意需要两边带上 "`" ,且 "`" 与 "$" 之间不能有空格
`$\sigma$`
% 多行公式
$$
\begin{aligned}f(x) &= \sum_{i=1}^{\infty}{\frac{x}{2^i}} \\
&= x\end{aligned}
$$ -
用这种方案,不会造成 LaTeX 与 Markdown 语法之间的冲突。在文中使用 LaTeX 语法不需要转义。 以下公式可以直接使用,不会造成任何问题:
1
2\epsilon_0
\begin{eqnarray*}
hexo-renderer-kramed 插件还有其他可配置项,请参考插件文档: https://github.com/sun11/hexo-renderer-kramed
几种公式显示方案各有优缺点:
- 动态渲染方案 LaTeX 语法不需要转义,能更好的支持从其他地方导出的 Markdown 文件。但因为需要在浏览器渲染,页面显示会略有延迟。
- 静态渲染方案将公式直接编译在静态文件里,显示性能更优,但语法需要转义。
- hexo-renderer-pandoc 快速显示公式而不必经历转义语法的麻烦,但需要安装 Pandoc。
图表支持
修改 Hexo 目录 下的 _config.arknights.yml
文件:
1 | # 图表支持 |
主题通过 mermaid-js 绘制各种图表。查看示例
支持: 流程图 | 序列图 | 类图 | 状态图 | 实体关系图 | 用户旅程图 | 甘特图 | 指令图 | 饼图
语法:
1 | <div class="mermaid"> |
如果习惯使用
代码块
也完全支持。
字数/阅读时长统计
依赖 hexo-wordcount
:
npm 用户:
1 | cnpm install hexo-wordcount --save |
yarn 用户:
1 | yarn add hexo-wordcount |
之后修改 Hexo 目录 下的 _config.arknights.yml
文件:
1 | post: |
浏览量统计
使用 不蒜子 进行浏览量统计。 修改 Hexo 目录 下的 _config.arknights.yml
文件启用该功能:
1 | busuanzi: |
文档加密
经过修改的 hexo-blog-encrypt 插件已适配并集成在本主题中(目前仅支持 default 与 up 主题)。
在 Hexo/_config.yml
文件中添加以下内容:
1 | # Security |
或 在文章的 Front-matter 区内设置:
1 |
|
搜索
默认开启,若要关闭,在 Hexo/_config.arknights.yml
文件中:
1 | search: |
Front-matter
除了 Hexo 支持的 Front-matter 还支持:
1 | # 文章页右上角发布/更新日期 |
引入自定义 CSS/JS 文件
可以在 Hexo/source/css/
目录下放入自己的 CSS 文件; 在 Hexo/source/js/
目录下放入自己的 JavaScript 脚本文件;
然后修改 Hexo/_config.arknights.yml
文件:
1 |
|
资源文件夹是存放用户资源的地方。 除
_posts
文件夹之外,开头命名为_
(下划线)的文件/文件夹和隐藏的文件将会被忽略。 Markdown 和 HTML 文件会被解析并放到public
文件夹,而其他文件会被拷贝过去。——来自 Hexo 官方文档
参与开发
分支说明
分支 | 说明 |
---|---|
main | 相对稳定的版本 |
gh-pages | gh-page 托管 |
hexo | Hexo 目录,这里有可以用于测试主题的 .md 文件 |
开发中可能遇见的问题及解决方法
修改 TS 文件不生效
TypeScript 需要手动编译,请全局安装 typescript
后在 arknights\source\js\_src
目录下执行 tsc
以编译。
运行 hexo serve --debug
时,长文章渲染不全
这是由热重载插件 hexo-browsersync
导致的,不会影响发布。
解决方法:禁用该插件。(反正不影响发布,不管也行)
参与开发可能需要的文档
-
另外引用几个大佬的 Blog