按标签列出Jekyll Collection页面

时间:2016-04-30 19:01:37

标签: jekyll

我正在尝试按标签分组的集合中的页面列表。我知道这可以通过Jekyll的内置site.tags功能轻松实现,我可以(并且已经)通过以下方式实现:

 <h3>Tags</h3>

{% for tag in site.tags %}
  {% assign t = tag | first %}
  {% assign posts = tag | last %}

<h4><a name="{{t | downcase | replace:" ","-" }}"></a><a class="internal" href="/tagged/#{{t | downcase | replace:" ","-" }}">{{ t | downcase }}</a></h4>

<ul>
{% for post in posts %}
  {% if post.tags contains t %}
  <li>
    <a href="{{ post.url }}">{{ post.title }}</a>
    <span class="date">{{ post.date | date: "%B %-d, %Y"  }}</span>
  </li>
  {% endif %}
{% endfor %}
</ul>

<hr>

{% endfor %}

为了得到这个:

Grouped by tags

我想在名为site.tags的Collection中复制note函数。我的馆藏中的标签被分组,就像它们用于帖子一样,使用例如YAML标题中的tags: [urban growth, California, industrialization]。但是我希望能够使用Collection来实现这一点。我几乎可以通过以下方式实现我的目标:

{% assign collection = site.note | group_by: "tags" | uniq %}
{% for group in collection %}
{% comment %} This is super hacky and I don't like it {% endcomment%}
  <h3>{{ group.name | replace: '"', '' | replace: '[', '' | replace: ']', '' }}</h3>
  <ul>
  {% for item in group.items %}
    <li><a href="{{ item.url | prepend: site.baseurl | prepend: site.url }}">{{ item.title }}</a></li>
  {% endfor %}
  </ul>
{%endfor%}

但正如你可能看到的那样,这并没有将标签分解成他们独特的群体;相反,YAML中的每组标签都被视为单个大标签。有关构造唯一标记数组并在其下列出Collection页面的任何指针吗?

2 个答案:

答案 0 :(得分:14)

试试这个:

{% assign tags =  site.note | map: 'tags' | join: ','  | split: ',' | uniq %}
{% for tag in tags %}
  <h3>{{ tag }}</h3>
  <ul>
  {% for note in site.note %}
    {% if note.tags contains tag %}
    <li><a href="{{ site.baseurl }}{{ note.url }}">{{ note.title }}</a></li>
    {% endif %}
  {% endfor %}
  </ul>
{% endfor %}

答案 1 :(得分:3)

David Jacquel的答案中提到的tags分配方法可以简化为:

{% assign tags =  site.note | map: 'tags' | uniq %}