我用的主题是 PaperMod,本文用它来作示例。
所有路径必须使用相对路径(不要加前导斜杠)!
如果要在文章页面中显示目录,请关注以下配置:
params:
showToc: true # 全局显示目录
tocopen: true # 全局目录展开(目录默认是折叠列表)
这里的配置很容易出问题。如果你像我一样喜欢搞多语言博客,请关注以下配置:
defaultContentLanguage: zh-cn
defaultContentLanguageInSubdir: true
defaultContentLanguage: zh-cn
以上配置不要修改,除非的确要修改默认语言。
defaultContentLanguageInSubdir: true
举例:
# 当 defaultContentLanguageInSubdir: true
public/
├── zh-cn/ # 默认语言(中文)内容
│ └── posts/
└── en/ # 其他语言内容
└── posts/
# 当 defaultContentLanguageInSubdir: false
public/
├── posts/ # 默认语言(中文)内容
└── en/ # 其他语言内容
└── posts/
需要配置多语言 content 目录:
languages:
zh-cn:
languageName: "简体中文"
contentDir: "content/zh-cn" # content/<lang>
# ... 需要做多语言配置的配置都可以写进这里
en:
languageName: "English"
contentDir: "content/en"
# ...
在多语言配置下,search.md
和 archive.md
有效路径为:
content/
├── zh-cn/
│ ├── posts/
│ ├── search.zh-cn.md # search.<lang>.md
│ └── archive.md
└── en/
├── posts/
├── search.en.md
└── archive.md
以上两者的 URL 在 hugo.yaml
中保持一般设置即可:
languages:
zh-cn:
menu:
main:
- identifier: "search"
name: "搜索"
url: "search"
weight: 1
- identifier: "archives"
name: "归档"
url: "archives"
weight: 2
要支持搜索功能,必须在 hugo.yaml
中做如下配置:
outputs:
home:
- HTML
- RSS
- JSON # JSON 是支持搜索的关键
我想要英文使用 Ubuntu Mono,中文使用 HarmonyOS Sans SC,代码使用 JetBrains Mono,于是做了如下配置。
新建 themes/PaperMod/assets/css/extended/fonts.css
:
@import url('https://cdn.jsdelivr.net/npm/ubuntu-mono/css/ubuntu-mono.min.css?display=swap');
@import url('https://cdn.jsdelivr.net/npm/harmonyos-sans-font/css/harmonyos-sans.min.css?display=swap');
@import url('https://cdn.jsdelivr.net/npm/jetbrains-mono/css/jetbrains-mono.min.css?display=swap');
body {
font-family: "Ubuntu Mono", "HarmonyOS Sans SC", sans-serif;
}
code, pre {
font-family: "JetBrains Mono", monospace;
}
默认的代码块背景色亮度很低(非常黑),我修改了一下。
在 themes/PaperMod/assets/css/common/post-single.css
第 206 行处,可以看到 --code-block-bg
变量决定了代码块背景色:
.post-content pre code {
display: grid;
margin: auto 0;
padding: 10px;
color: rgb(213, 213, 214);
background: var(--code-block-bg) !important;
border-radius: var(--radius);
overflow-x: auto;
word-break: break-all;
}
全局搜索后发现 themes/PaperMod/assets/css/core/theme-vars.css
中有两处声明了这个变量:
:root {
...
--code-block-bg: rgb(43, 43, 43);
...
}
.dark {
...
--code-block-bg: rgb(43, 43, 43);
...
}
都改成 rgb(43, 43, 43)
就可以了。
我使用的是 Giscus,它是利用 GitHub Discussions 实现的评论系统。
请确保:
然后访问 Giscus 网站,按要求进行配置。
配置完成后,在“启用 giscus”标题下会出现形如以下内容:
<script src="https://giscus.app/client.js"
data-repo="[在此输入仓库]"
data-repo-id="[在此输入仓库 ID]"
data-category="[在此输入分类名]"
data-category-id="[在此输入分类 ID]"
data-mapping="pathname"
data-strict="0"
data-reactions-enabled="1"
data-emit-metadata="0"
data-input-position="bottom"
data-theme="preferred_color_scheme"
data-lang="zh-CN"
crossorigin="anonymous"
async>
</script>
新建 layouts/partials/comments.html
,将得到的 <script> 标签复制粘贴进去。
确保 hugo.yaml
中启用了评论:
params:
comments: true
敲打 hugo -D
命令后,Hugo 会在 public
目录下构建静态博客。每次构建前一般会将 public
删掉来确保新构建的内容不出问题。
在这种情况下,我希望只部署静态博客到仓库中,而不是整个 Hugo 框架。于是写了一个 Shell 脚本:
@echo off
hugo -D
cd public
git init
git remote add origin [email protected]:<user>/<repo>.git
git checkout -b main
git fetch
git add -A
git commit -m "temp"
git reset --soft origin/main
git commit -m "update %date%"
git push
cd ..
因为不方便维护,我又改用同一仓库中单独创建源码分支和部署分支的方法。于是乎:
# 在主仓库创建 public 分支
git checkout --orphan public
git reset --hard
git commit --allow-empty -m "Init public branch"
git push origin public
git checkout main
# 将 public 目录关联到 public 分支
git worktree add -B public public origin/public
# 生成网站并推送
hugo -D
cd public
git add -A
git commit -m "Push %date%"
git push origin public
cd ..
结合 Cloudflare Pages 自带 CI/CD,只需一个脚本即可实现一键推送更新。
不要在 hugo.yaml
中配置 baseURL
,这会导致所有部署唯一预览 URL 被重定向到 baseURL
。
hugo.yaml
示例这是我使用的 hugo.yaml
。