Featured image of post Hugoで関連記事を表示する

Hugoで関連記事を表示する

Relatedって機能です

関連記事を表示する

Hugoには関連記事を表示する機能が備わっています。

これ → {{ $related := .Site.RegularPages.Related . | first 5 }}

具体的には、こんな感じで行います。

  1. 関連記事を表示するhtmlを用意する
  2. 記事ページの所定位置に埋め込む
  3. 重み付けをする

関連記事を表示するhtmlを用意する

関連記事を表示させるためのhtml(ここではrelated.html)を用意します。

ファイルの場所
layouts/partials/related.html

{{ $related := .Site.RegularPages.Related . | first 5 }}
{{ with $related }}
<h3>See Also</h3>
<ul>
 {{ range . }}
 <li><a href="{{ .RelPermalink }}">{{ .Title }}</a></li>
 {{ end }}
</ul>
{{ end }}

1行目が関連記事の機能を使うための魔法。
たぶん、最初の5つを取得していると思います。

それ以下は、実際に表示させるためのhtmlです。
箇条書き(li)の部分は繰り返し処理になっているので、1行で済んでいます。

ちなみに上のサンプルは、公式サイトから転記です。
Related Content | Hugo

記事ページの所定位置に埋め込む

表示させたい場所にrelated.htmlを呼び出すコードを追記します。

ファイル
layouts/default/single.html

{{- if (.Param "ShowRelated") }}
{{ partial "related.html" . }}
{{- end }}

2行目だけで成立しますが、設定ファイル(config.yml)内でShowRelatedがTrueのときに表示するというようにしておきました。

params:
  ShowRelated: true

重み付けをする

設定ファイル(config.yml)内で、関連度の重み付けをします。

related:
  includeNewer: true
  threshold: 80
  toLower: true
  indices:
    - name: keywords
      weight: 100
    - name: tags
      weight: 70
    - name: categories
      weight: 40
    - name: date
      weight: 10

数字が重みですね。
詳細は公式サイトをご覧ください。

Configure Related Content | Hugo

サンプル

こちらのサイトで関連記事の表示を行っています。
k-kaz が好きなことを書く

時間が出来たらここでも行おうかな・・・。

Hugo で構築されています。
テーマ StackJimmy によって設計されています。