Jekyll 按类别和优先级对集合进行分组和排序



我在一个集合中有一堆文档页面,它们都有一个类别,我正在使用group_by过滤器,如下所示:

{% assign docs_by_category = site.documentation | group_by: "category" %}

然后,我使用这些分组来创建菜单结构,其中每个类别的项目都列在标题下。这一切都很好。

但是,我的问题在于能够排序,哪个类别首先显示,所以我希望能够以某种方式确定它们的优先级。

说,如果我有以下类别:tutorials, getting started, advanced.我不希望advanced显示为第一类,而是getting started.

用于生成菜单的当前代码如下所示:

{% assign navurl = page.url | remove: 'index.html' %}
{% assign docs_by_category = site.documentation | group_by: "category" | reverse %}
{% for category in docs_by_category %}
<div class="category_wrapper">
<div class="category">{{ category.name }}</div>
<ul>
{% for item in category.items %}
<li class="collapsed">
<a href="{{ site.baseurl }}{{ item.url }}">
{% if item.url == navurl %}
<u>{{ item.title }}</u>
{% else %}
{{ item.title }}
{% endif %}
</a>
</li>
{% endfor %}
</ul>
</div>
{% endfor %}

TL;DR:如何按优先级对组进行排序?

您可以使用配置数组来存储类别顺序:

# _config.yml
categories-order:
- getting started
- tutorials
- advanced

然后:

{% assign docs_by_category = site.documentation | group_by: "category" %}
{% for cat in site.categories-order %}
{% assign currentCat = docs_by_category | where: 'name', cat | first %}
<div class="category_wrapper">
<div class="category">{{ currentCat.name }}</div>
<ul>
{% for item in currentCat.items %}
<li class="collapsed">
<a href="{{ site.baseurl }}{{ item.url }}">
{% if item.url == navurl %}
<u>{{ item.title }}</u>
{% else %}
{{ item.title }}
{% endif %}
</a>
</li>
{% endfor %}
</ul>
</div>
{% endfor %}

这意味着您在配置中引用所有类别,否则,它们将不会出现在此列表中。

最新更新