Hugo 布局将 h3 内容拆分为 div

Hugo layouts split h3 content to div

我想知道如何修改简单 test.md 文件的内容以通过以下方式使用 hugo 生成 .html - 每个 h3 (###) 和所有提前放入的代码,直到下一个 h3 .简单来说,我想将每个 h3 部分拆分为单独的选项卡,标题与 h3 标签相同。

test.md 文件如下所示:

---
title: "Some title"
layout: test
---


## Title

### some content
lorem ipsum 1

### some content 2
lorem ipsum 2

### some content 3
lorem ipsum 3

所需的 hugo 输出如下所示:

<h2 id="title">Title</h1>
<div class="tabs">
  <div class="tab" id="some content">
    <h3 id="some-content">some content</h2>
    <p>lorem ipsum 1</p>
  </div>
  <div class="tab" id="some content">
    <h3 id="some-content-2">some content 2</h2>
    <p>lorem ipsum 2</p>
  </div>
  <div class="tab" id="some content">
    <h3 id="some-content-3">some content 3</h2>
    <p>lorem ipsum 3</p>
  </div>
</div>

如果可能的话,我想使用 Hugo 模板创建它,但一些 javascript 技巧也是可以接受的。感谢您提供任何线索。

我有一个类似的功能要实现(只有 Hugo,没有 javascript),我必须在我的主题中定义一个 Hugo partial template

themes/mytheme/layouts/partials/boxtext.html中:

{{ $paragraphs := split .Content "<h2 " }}

{{ range $index, $p := $paragraphs }}
    {{ $pp := trim $p " \n" }}
    {{ if (eq $index 0) }}
        {{ printf "%s\n" $pp | safeHTML }}
    {{ end }}
    {{ if and (ne $pp "") (gt $index 0) }}
    <div class="boxtext">
        {{ printf "<h2 %s\n" $pp | safeHTML }}
    </div>
    {{ end }}
{{end}}

(这不是按照您的意愿执行相同的输出:根据您的情况调整它,以 split .Content "<h3 " 而不是 h2 开头!)

实际上,为了确保不生成额外行并保持紧凑,我不得不将其重写为:

{{ $paragraphs := split .Content "<h2 " }}{{ range $index, $p := $paragraphs }}{{ $pp := trim $p " \n" }}{{ if (eq $index 0) }}{{ printf "%s\n" $pp | safeHTML }}{{ end }}{{ if and (ne $pp "") (gt $index 0) }}    <div class="boxtext">
        {{ printf "<h2 %s\n" $pp | safeHTML }}
    </div>{{ end }}{{end}}

然后我的 single.html 模板页面,我网站的相关部分可以包装 HTML 代码生成的代码:{{ partial "boxtext.html" . }}

如:

> cat "themes/mytheme/layouts/mysection/single.html"
{{ define "main" }}

<body id="id1">
    <div id="top">
        <ul class="menu">
        </ul>
    </div>
    <div>
        <div id="header">
            <h1>{{.Title}}</h1>
        </div>
    </div>
    <div>{{ range .Resources }}{{ if .RelPermalink }}
      <li>azza2<a href="{{ .RelPermalink }}">{{ .ResourceType | title }}</a></li>{{ else }}
      <li>{{ .ResourceType | title }} (no link, only embedded in page)</li>{{ end }}{{ end }}
    </div>
    {{ partial "boxtext.html" . }}
</body>