我如何迭代grav cms中主博客页面中的所有标签

时间:2018-03-09 16:15:32

标签: php twig content-management-system yaml grav

我在user/config/site.yaml文件中定义了以下内容。

title: Grav
author:
  name: Joe Bloggs
  email: 'joe@test.com'
metadata:
    description: 'Grav is an easy to use, yet powerful, open source flat-file CMS'
taxonomies: [tag,author]

如您所见,我将以下内容定义为tamonomies:

taxonomies: [tag,author]

现在在我的个人博客文章中,我在标题中定义了以下内容:

---
title: 'My Blog post one'
visible: true
summery: 'Pellentesque ornare mi nec elementum fringilla. Nam aliquam urna metus, vel convallis leo vulputate ut. Sed ac tempor turpis, ut pellentesque nisi. Nulla in dui sit amet augue iaculis euismod ac a massa. Sed sollicitudin nibh nisi, eu efficitur ligula vulputate a.'
header_image_file : css-thumb.jpg
taxonomy:
    tag: [JS, jQuery , CSS]
    author: papita
---

如您所见,我定义了以下标签:

tag: [JS, jQuery , CSS]

ISSUE :: -

我想做的是在侧栏中的主要博客页面中输出列表中的所有标签,如下所示:: -

<ul>
  <li><a href="">{{ tag name }}</a><span>{{  number of articles that are tagged with this tag name }}</span></li>
  <li><a href="">{{ tag name }}</a><span>{{  number of articles that are tagged with this tag name }}</span></li>
  <li><a href="">{{ tag name }}</a><span>{{  number of articles that are tagged with this tag name }}</span></li>
</ul>

现在我尝试了以下两种让我接近的方法:

<ul> 
    {% for post in page.collection() %}
        <li><a href={{ post.url }}> {{ post.title }} </a></li>
    {% endfor %}
</ul> 

这个当然不会给我标签名称,而只是每个博客个人博客帖子。我也尝试了以下内容:

<ul> 
    {% for tag in config.site.taxonomies %}
        <li><a href="#"> {{ tag }} </a></li>
    {% endfor %}
</ul>

但这似乎没有多大好处,我还能尝试什么,以便获得理想的结果?如何迭代所有标签,并显示为每个标签发布的文章数量?

1 个答案:

答案 0 :(得分:1)

如果您在页面.md文件的标题中定义了代码,则可以使用以下代码段轻松覆盖它们:

{% for tag in page.taxonomy.tag %} <li><a href="#"> {{ tag }} </a></li> {% endfor %}

有关详细信息,请查看官方文档或grav默认主题Quark

https://learn.getgrav.org/content/taxonomy

https://github.com/getgrav/grav-theme-quark/blob/develop/templates/partials/blog/taxonomy.html.twig

一般情况下,我建议您查看官方Grav页面上针对此类问题的默认主题和演示。通常你会找到适合你需要的例子。