作者热门文章
- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在构建一个简单的 Hugo 博客,我有一个页面的以下 toml 配置
+++
[publications]
links = ["2017/article1",
"2017/article2"]
+++
我将这些文件放在相应的内容部分 (content/publications/2017/article1.md)。我需要的是遍历它们,加载每个页面并使用它们的一些 .Params
构建部分。有点像
{{ range .Params.publications.links }}
{{ do something with page parameters }}
{{ end }}
我想这是一个基本的 Hugo 问题,我就是想不出来。
最佳答案
这实际上需要对 Hugo 模板进行一些非常高级的使用。但你可以做到!
首先,为方便起见,请将“.md”扩展名添加到您尝试访问的页面。添加完整路径可能也是一个好主意,这样如果您将来在不同的目录中添加具有相同名称的文件,Hugo 就不会得到错误的文件。
+++
[publications]
links = ["publications/2017/article1.md",
"publications/2017/article2.md"]
+++
然后你可以在你的模板中使用类似下面的东西。
{{ range .Params.publications.links }}
{{ range where $.Site.Pages "URL" ($.RelRef .) }}
The "{{ .Title }}" page has {{ .WordCount }} words.
{{ end }}
{{ end }}
这使用了 where
function通过 URL 字段过滤所有站点页面的数组。要查找 URL,它使用 .RelRef
page variable带有链接文本。
我认为还应该有一种方法可以在没有内部 range
语句的情况下使用 apply
函数来执行此操作,但我无法让它工作。
关于go - 如何通过 markdown 名称遍历 hugo 页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43440708/
我是一名优秀的程序员,十分优秀!