跳过正文
  1. 文档/

局部模板(Partials)

4 分钟· ·
Partials 统计服务 隐私 评论 网站图标 图标 文档
目录
部署教程 - 这篇文章属于一个选集。
§ 9: 本文

站点分析
#

Blowfish 支持了 Fathom、Google 和 Umami。Fathom 和 Umami 都是开源、简单、且注重隐私的站点分析服务,他们可以很好地替代 Google 分析。Fathom 和 Umami 都有公有云的付费版本,当然你也可以自己手动部署开源版。

Fathom
#

要启用 Fathom Analytics 支持,只需在 config/_default/params.toml 文件中提供您的 Fathom 站点代码。如果您还使用 Fathom 的自定义域功能,并希望从您的域中提供脚本,还可以额外提供 domain 配置值。如果不提供 domain 值,脚本将直接从 Fath只需要在 config/_default/params.toml 文件提供你的 Fathom 站点代码,就可以快速支持 Fathom 站点分析。 如果你想使用自定义域名来获取跟踪脚本, 那么需要提供 domain 参数,否则会从 Fathom 云服务版的地址 (<cdn.usefathom.com>) 获取脚本。

# config/_default/params.toml

[fathomAnalytics]
  site = "ABC12345"
  domain = "llama.yoursite.com"

Google
#

Hugo partial 本身已经支持了 Google 站点分析。只需要在 config/_default/config.toml 文件添加 googleAnalytics 参数即可,跟踪脚本会自动添加。

版本3 (analytics.js) 和版本4 (gtag.js) 都是支持的,参考如下示例:

# config/_default/config.toml

# 版本 3
googleAnalytics = "UA-PROPERTY_ID"
# 版本 4
googleAnalytics = "G-MEASUREMENT_ID"

Umami
#

只需要在 config/_default/params.toml 文件提供你的 Umami 跟踪代码,就可以快速支持 Umami 站点分析。 如果你想使用自定义域名来获取跟踪脚本, 那么需要提供 domain 参数,否则会从 Umami 云服务版的地址 (analytics.umami.is) 获取脚本。 如果你只想在特别的数个域名中使用 tracker 功能,那么需要提供 dataDomains 参数。否则任何一个匹配了 websiteiddomain 参数值的网站,Umami 脚本都会执行。如果环境变量配置了 TRACKER_SCRIPT_NAME 可以填写自定义的脚本名称 scriptName,如果没有配置就注释掉或者填写默认的 script.js

Note: 开启 Umami 网站分析后, Blowfish 会自动支持 Umami 事件追踪。如果你不想支持此功能,需要把参数 enableTrackEvent 设置为 false
# config/_default/params.toml

[umamiAnalytics]
  websiteid = "ABC12345"
  domain = "llama.yoursite.com"
  dataDomains = "yoursite.com,yoursite2.com"
  scriptName = "TRACKER_SCRIPT_NAME"
  enableTrackEvent = true

Seline
#

只需要在 config/_default/params.toml 文件提供你的 Seline token,就可以快速支持 Seline 站点分析。

Note: 开启 Seline 网站分析后, Blowfish 会自动支持 Seline 事件追踪。如果你不想支持此功能,需要把参数 enableTrackEvent 设置为 false
# config/_default/params.toml

[selineAnalytics]
  token = "XXXXXX"
  enableTrackEvent = true

提供自定义站点分析
#

如果你想在你的网站提供其他站点分析,你可以自己提供脚本,并覆盖 Blowfish 主题中内置的 partial。 只需要创建 layouts/partials/extend-head.html 文件并在内容中提供脚本即可,Blowfish 主题会自动将 extend-head.html 中的内容添加到整个站点的 <head> 中。

评论
#

Blowfish 支持了在每篇文章底部添加一个评论功能。只需要提供一个 layouts/partials/comments.html 文件,并在其中添加显示评论的代码即可。

你可以使用 Hugo 中内置的 Disqus 模板,也可以提供自定义代码。更多内容和细节可以参考 Hugo 文档.

一旦提供了评论的 partial,你就可以使用 showComments 更细致地控制评论的显隐。此参数可以在 params.toml 配置文件 中全局设置,也可以在每篇文章的 扉页参数 中单独针对特定文章设置。该参数默认为 false,因此需要在上面两个位置设置为 true 才能显示评论。

网站图标(Favicons)
#

Blowfish 提供了一套空白网站图标以便快速上手,但你可以提供自己的资源来覆盖他们。想要获取新的图标资源最简单的方法是使用第三方提供商,如 favicon.io

网站图标资源的位置在 static/ 文件夹中,并务必按照如下的名称命名。如果你使用了favicon.io,那么下载下来的文件名和下面的示例完全一致;当然你也可以通过别的方式提供,记得重命名就行。

static/
├─ android-chrome-192x192.png
├─ android-chrome-512x512.png
├─ apple-touch-icon.png
├─ favicon-16x16.png
├─ favicon-32x32.png
├─ favicon.ico
└─ site.webmanifest

或者,您也可以完全覆盖默认的 favicon 行为,提供自己的 favicon HTML 标签和资源。只需在项目中提供一个 layouts/partials/favicons.html 文件,该文件就会被加入网站的 <head> 中,取代默认资源。

Icon 图标
#

与 [图标简码](https://blowfish.page/zh-cn/docs/shortcodes/#icon)类似,您也可以通过使用 Blowfish 的 icon.html partial,在自己的模板和 partial 中加入图标。该部分包含一个参数,即要包含的图标名称。

示例:

  {{ partial "icon.html" "github" }}

图标使用 Hugo 管道填充,因此非常灵活。Blowfish 内置了大量用于社交、链接和其他用途的图标。请查看[图标示例](https://blowfish.page/zh-cn/samples/icons/)页面,查看支持图标的完整列表。

可以通过在项目的 assets/icons/ 目录中提供自己的图标资源来添加自定义图标。然后,可以通过使用 SVG 文件名(不含.svg扩展名)在局部中引用图标。

图标还可通过调用[图标简码](https://blowfish.page/zh-cn/docs/shortcodes/#icon)在文章内容中使用。

扩展
#

Blowfish 还提供了许多扩展 partial,可以扩展基本功能。

文章链接
#

如果您希望在文章链接后插入附加代码,请创建一个 layouts/partials/extend-article-link.html 文件。如果与badge简码结合使用,该功能将尤为强大,可用于突出显示某些文章的元数据。

头部和尾部
#

本主题允许在模板的<head><footer>部分直接插入附加代码。这些代码可用于提供不属于主题的脚本或其他逻辑。

只需创建layouts/partials/extend-head.htmllayouts/partials/extend-footer.html,这些部分就会自动包含在网站构建中。这两个 partial 将作为最后一项注入到 <head><footer> 中,因此它们可用于覆盖主题默认值。

部署教程 - 这篇文章属于一个选集。
§ 9: 本文

相关文章

Front Matter(文件头信息)
3 分钟
Front Matter 配置 文档
主页布局
3 分钟
主页 布局 文档
入门指南
5 分钟
安装 文档
多创作者模式
3 分钟
作者 配置 文档
安装和配置
4 分钟
安装 文档
托管和部署
3 分钟
文档 托管 部署 Github Netlify 渲染器