将网站集从页面传递到布局jekyll

时间:2020-04-24 06:34:59

标签: ruby jekyll liquid jekyll-theme

我正试图将一个网站集传递到页面的布局中,以便能够根据传递的部分来创建导航菜单。

在我的_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从页面传递到布局,则一切正常。但是,当我尝试通过收藏夹时,它不起作用。

感谢您的帮助。

1 个答案:

答案 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 }}