Hugo 引入Giscus评论系统
系列 - Hugo相关
目录
1 选择评论系统
DoIt
主题支持的评论功能:
- disqus
- utterances
- giscus
- gitalk
- valine
- waline
- telegram
- …
技巧
utterances、gitalk 是基于 GitHub Issue 的评论系统, disqus 是基于 GitHub Discussions, 如果你的网站是基于 GitHub Pages 部署的, 那么这三个评论系统都是不错的选择.
由于我使用的是DoIt
主题,是支持了多个评论系统的,因为Giscus
在更新,并且有回复功能,管理评论功能,所以我选择了Giscus
作为评论系统.
utterances、gitalk 是可以一键迁移到 Giscus 的,所以如果你之前使用的是这两个评论系统,可以考虑迁移到 Giscus.
2 Giscus简介
【Giscus中文官网】- 开源
- 无跟踪,无广告,永久免费
- 无需数据库。所有数据均储存在 GitHub Discussions 中
- 支持自定义主题
- 支持多种语言
- 高可配置性
- 自动从GitHub 拉取新评论与编辑
- 可自建服务
3 怎么用
3.1 选择仓库开启GitHub Discussions
功能
以我仓库为例,我博客是部署在github pages上的,所以我需要在我的仓库中开启GitHub Discussions
功能.
提示
也可以新建一个其他仓库,用来存放评论数据,这样可以更好的管理评论数据.
比如我的仓库是andy90s/andy90s.github.io
,我需要在这个仓库的设置中开启GitHub Discussions
功能.

找到Discussions
选项,点击勾选按钮,开启GitHub Discussions
功能.

3.2 安装Giscus
点击 【安装】
安装提示选择的仓库,有两个选项
- All repositories
- Only select repositories
选择Only select repositories
,然后选择你的仓库,点击Install
按钮.

3.3 配置Giscus
设置仓库:

选择分类:

其他保持默认即可,往下拉查看生成的配置:

3.4 Hugo配置
在config.toml
中添加配置:
[page]
[page.comment]
enable = true
[page.comment.giscus]
enable = true
# owner/repo
dataRepo = "你的仓库示例:andy90s/andy90s.github.io"
dataRepoId = "上面配置生成的"
dataCategory = "Announcements"
dataCategoryId = "上面配置生成的"
dataMapping = "pathname"
dataStrict = "0"
dataReactionsEnabled = "1"
dataEmitMetadata = "0"
dataInputPosition = "bottom"
lightTheme = "light"
darkTheme = "dark"
dataLang = "zh-CN"
多语言
如果你的网站是多语言的, 可以根据语言配置不同的评论系统. 参考
DoIt
主题的demo网站配置. config.toml多语言配置.3.5 本地测试
在本地启动hugo服务,查看是否正常显示评论系统.
hugo server -e production
注意
默认开发环境是没有评论的, 所以要强制开启生产环境.