在Hugo中,有一种非常有用的功能,即可以根据条件来渲染多个部分。这种功能可以使得我们根据特定的情况或条件来展示/隐藏页面的某些部分。无论是在构建静态网站还是动态网站中,这种条件渲染的功能都能够帮助我们更加灵活地控制页面的呈现方式。在本文中,我将和大家一起探讨如何在Hugo中实现条件渲染多个部分的方法及使用场景。
问题内容
我想渲染除网站主页中的静态文件之外的每个文件夹中的所有 markdown 文件,一种方法是在 hugo 中使用 union,但随着文件夹数量的增加,我发现自己在重复 union到处都是(带联合的代码被注释了,顺便说一下,它正在工作),所以我认为使用切片会是一个更好的主意,但是当我尝试使用切片时,我收到以下错误 -
渲染页面失败:“home”渲染失败:“(目录路径)\layouts\index.html:12:19”:在 <.pages> 处执行模板失败:无法评估字符串类型中的字段页面
目录结构
index.html 代码
{{ define "main" }}
{{$sectionNames := slice "posts" "problems" "tutorials"}}
{{range $index, $sectionName := $sectionNames}}
{{ range where .Pages "Section" $sectionName }}
{{}}
-
{{.Title}}
{{ range .Pages }}
{{.Title}} · {{.Date.Format "January 2, 2006"}}
{{ end }}
{{end}}
{{end}}
{{ end }}解决方法
https://www.php.cn/link/1330fef5fe4f742c1918c585c2da13b3一个>:
上下文(又名“点”)
关于 go 模板,最容易被忽视的概念是 {{ . }}
始终引用当前上下文。
- 在模板的顶层,这将是可供模板使用的数据集。
- 但是,在迭代内部,它将具有循环中当前项的值;即
{{ . }}
将不再引用整个页面可用的数据。
在下面的代码中,.pages
中的点具有第一个 range
操作中当前项目的值。该值的类型是字符串,并且它没有字段 pages
。这就是为什么它失败了,execute of template failed at <.pages>: can'tvaluate field pages in type string
.
{{ define "main" }}
{{$sectionnames := slice "posts" "problems" "tutorials"}}
{{range $index, $sectionname := $sectionnames}}
{{ range where .pages "section" $sectionname }}
^^^^^^
一种可能的修复方法是使用 $.
访问全局上下文:.pages
==> $.pages
。
也许更好的解决方案是列出排除部分。那么当添加更多文件夹时就不需要修改代码了:
{{ define "main" }}
{{ range where .Pages "Section" "!=" "static" }}
以上就是在 Hugo 中有条件地渲染多个部分的详细内容,更多请关注编程网其它相关文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
软考中级精品资料免费领
- 历年真题答案解析
- 备考技巧名师总结
- 高频考点精准押题
- 资料下载
- 历年真题
193.9 KB下载数265
191.63 KB下载数245
143.91 KB下载数1142
183.71 KB下载数642
644.84 KB下载数2755
相关文章
发现更多好内容猜你喜欢
AI推送时光机在 Hugo 中有条件地渲染多个部分
后端开发2024-02-09为什么在这个 golang 示例中,互斥体部分中包含的条件不会出现死锁?
后端开发2024-02-13 咦!没有更多了?去看看其它编程学习网 内容吧