我正试图将一个网站集传递到页面的布局中,以便能够根据传递的部分来创建导航菜单。
在我的_config.yml
中collections:
tt:
output: true
在我的index.md页面中:
---
layout: mylayout
title: My Great Homepage
icon: fa-home
order: 1
sec: "{{site.tt}}"
---
在我的布局中:
---
layout: mylayout
---
{%- assign _sections = page.sec | flatify -%}
{%- include header.html scrolly_nav=_sections -%}
<!-- Main -->
<div id="main">
{{page.sec | flatify}} <!-- just to debug -->
</div>
Flatify在_plugins / flatify.rb下:
module Jekyll
module ExpandNestedVariableFilter
def flatify(input)
Liquid::Template.parse(input).render(@context)
end
end
end
Liquid::Template.register_filter(Jekyll::ExpandNestedVariableFilter)
在我的布局中,使用{%- assign _sections = site.sec | flatify -%}
可以很好地工作,但是当我将集合从页面传递到布局时,它不起作用。
如果我执行完全相同的操作,而不是将site.title
从页面传递到布局,则一切正常。但是,当我尝试通过收藏夹时,它不起作用。
感谢您的帮助。
答案 0 :(得分:1)
您的flatify插件很棒,但不能反映现实生活。
您不能在前端使用液体var,因为它们没有被解析。
在页面的最前面:
---
sec: "tt"
---
然后,从页面或布局中,您只需调用:
{%- assign _sections = site[page.sec] -%}
{%- include header.html scrolly_nav=_sections -%}
如果要调试,可以使用inspect
过滤器,该过滤器仅输出可变内容。
{{ page.sec | inspect }} or {{ site[page.sec] | inspect }}