在一些页面(不是全部)的前面,我有:
---
top-navigation:
order: 2
---
使用液体我想过滤所有具有top-navigation
对象并按top-navigation.order
排序的网站页面。
我正在尝试sort:'top-navigation.order'
,但这会引发undefined method [] for nil:NilClass
的例外。我试过了where:"top-navigation", true
,但这并不等同于真正的价值观。
如何过滤包含top-navigation
然后排序的网页?
答案 0 :(得分:5)
两个步骤:
创建一个包含top-navigation
键的页面的数组。
我们创建一个空数组,然后推送具有该键的项目。
{% assign navposts = ''|split:''%}
{% for post in site.posts %}
{% if post.top-navigation %}
{% assign navposts = navposts|push:post%}
{% endif %}
{% endfor %}
按top-navigation.order
{% assign navposts = navposts|sort: "top-navigation.order"%}
打印结果:
{% for post in navposts %}
<br>{{ post.title }} - {{post.top-navigation}}
{% endfor %}
对于页面使用site.pages
。
答案 1 :(得分:2)
在 Jekyll 3.2.0+(和 Github Pages)中,您可以像这样使用 where_exp 过滤器:
{% assign posts_with_nav = site.posts | where_exp: "post", "post.top-navigation" %}
这里,对于 site.posts 中的每个项目,我们将其绑定到 'post' 变量,然后评估表达式 'post.top-navigation'。如果它评估为真,那么它将被选中。
然后,把它和排序放在一起,你会得到这个:
{%
assign sorted_posts_with_nav = site.posts
| where_exp: "post", "post.top-navigation"
| sort: "top-navigation.order"
%}
Liquid 也有 where
过滤器,当你没有给它一个目标值时,它会选择所有具有该属性真值的元素:
{% assign posts_with_nav = site.posts | where: "top-navigation" %}
不幸的是,此变体不适用于 Jekyll。