我想在没有第一个的情况下显示新闻。我怎么能做到这一点?
以下是我必须更改的代码:
<div class="home-box-news carousel-news slide home-box-shadow" id="news" style="clear: both;">
<ol class="carousel-indicators news-box">
{% for i in 0..news|length-1 %}
{% if loop.index is not divisibleby (2) %}
<li data-target="#news" data-slide-to="{{ i / 2 }}" {% if loop.first %}class="active"{% endif %}></li>
{% endif %}
{% endfor %}
</ol>
<div class="carousel-inner">
{% for item in news %}
{% if loop.index is not divisibleby (2) %}
<div class="item{% if loop.first %} active{% endif %}">
<div class="carousel-caption">
{% endif %}
<h3><a href="{{ path('home_news_index') }}">{{ item.name }}</a></h3>
<p class="date">{{ item.createdAt|date('d.m.Y, G:i') }}</p>
<p {% if loop.index is divisibleby (2) %}style="border-bottom: 0;" {% endif %}>{{ item.content[:110]|nl2br }}{% if item.content|length > 110 %}... <a class="more" href="{{ path('home_news_index') }}">czytaj dalej</a>{% endif %}</p>
{% if loop.index is divisibleby (2) or loop.last %}
</div>
</div>
{% endif %}
{% endfor %}
</div>
</div>
答案 0 :(得分:6)
您可以使用slice过滤器,其工作方式类似于PHP中的array_slice()函数。
{% for item in news[1, news.length -1 ] %}
答案 1 :(得分:4)
把它放在循环中以省略第一条新闻
{% if loop.index0 > 0 %}
{# display your news #}
{% endif %}
答案 2 :(得分:4)
罗伯特建议的内容更简洁:
{% for item in news[1:] %}
答案 3 :(得分:1)
当然,还有另一个答案可能会/可能不会/更简洁/更简单-首先不要将行传递给Twig。