Icarus 主题设置

本文最后更新于:3 年前

本文内容都与当前使用的主题 Icarus 相关。

具体的主题设置可以见此链接,对应的 markdown 源代码可以见此链接

布局设施

侧边栏

设置sidebar中某个侧边栏的stickytrue来让它的位置固定而不跟随页面滚动。

_config.icarus.yml
1
2
3
4
5
sidebar:
left:
sticky: false
right:
sticky: true

样式更改

字体更改

觉得自带 Ubuntu 字体太丑了。 更改字体需要更改两个文件。

这个文件是告诉浏览器使用哪个字体的。

/Users/rui/Documents/Note/node_modules/hexo-theme-icarus/include/style/base.styl
1
2
// line 9
$family-sans-serif ?= 'Open Sans', 'Noto Serif SC', 'Microsoft YaHei', sans-serif

这个文件是告诉浏览器下载哪个字体的。

/Users/rui/Documents/Note/node_modules/hexo-theme-icarus/layout/common/head.jsx
1
2
3
// line 54
// 输入需要下载的字体即可
default: fontcdn('Open+Sans:wght@400;600&family=Source+Code+Pro', 'css2'),

同时部署时需要把文件拷进去。

参考:

主题定制

之后是一定会对主题进行定制的,但是近期没有时间,而且欠缺一些前端方面的知识。 这里记录一些见过的对 lcarus 定制的连接,用于学习和获得灵感。

List:

功能开启或添加

加入博客评论区 Gitalk

有很多插件可供选择,这里我们使用了 Gitalk,本质上是在 Github 上面新开一个 Repo,然后在 issue 区记录评论,然后通过 OAuth App 读写并显示到博客中。 具体的设置可以参见 Icarus 的用户评论插件

插件设置好之后可能会出现一些问题:

  • gitalk授权登录后报错403:一般来说是版本或 Proxy 的问题,需要升级版本或者更换 proxy,我选择了后者。参考 Gitalk 的 issue这篇博客
  • 文章批量初始化:我由于文章数较少,是一个一个手动初始化的,日后可能会需要用上批量初始化。

加入博客评论区 Giscus

Icarus 并没有对 Giscus 的支持,所以还是要从 index 文件层面进行改动。 整体来说愿意与 Gitalk 比较相似,不过不是在 issue 区记录评论,而是在 discussion 区记录。 回答可以按照层级展开,个人比较喜欢。

首先访问 Giscus 官网,获取对应的 html 代码,如下所示

1
2
3
4
5
6
7
8
9
10
11
12
13
14
<script src="https://giscus.app/client.js"
data-repo="xxxxxxxxx"
data-repo-id="xxxxxxxxx"
data-category="xxxxxxxxx"
data-category-id="xxxxxxxxx"
data-mapping="pathname"
data-reactions-enabled="1"
data-emit-metadata="0"
data-input-position="bottom"
data-theme="light"
data-lang="zh-CN"
crossorigin="anonymous"
async>
</script>

之后只需要将其放到原有的主题中放置 comments 的地方,替换原有代码即可。 在 Icarus 中对应的文件是 node_modules/hexo-theme-icarus/layout/common/comment.jsx。climbing

参考了以下几篇文章:

此外如果想要在 config 文件中控制 Giscus 的话,可以做以下更改

_config.icarus.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
giscus:
enable: true
data_repo: xxxxxxxxx
data_repo_id: xxxxxxxxx
data_category: xxxxxxxxx
data_category_id: xxxxxxxxx
data_mapping: pathname
data_reactions_enabled: 1
data_emit_metadata: 0
data_input_position: bottom
data_theme: light
data_lang: zh-CN
crossorigin: anonymous

comment.jsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
{(() => {
if (config.giscus.enable === true) {
return <script src="https://giscus.app/client.js"
data-repo={config.giscus.data_repo}
data-repo-id={config.giscus.data_repo_id}
data-category={config.giscus.data_category}
data-category-id={config.giscus.data_category_id}
data-mapping={config.giscus.data_mapping}
data-reactions-enabled={config.giscus.data_reactions_enabled}
data-emit-metadata={config.giscus.data_emit_metadata}
data-input-position={config.giscus.data_input_position}
data-theme={config.giscus.data_theme}
data-lang={config.giscus.data_lang}
crossorigin={config.giscus.crossorigin}
async>
</script>
}
})()}

Icarus 主题设置
https://blog.superui.cc/software-tools/hexo/Icarus/
作者
Superui
发布于
2020年11月24日
更新于
2022年3月23日
许可协议