3

我有一个带有以下块的树枝模板:

{% block dashboard %}
    {% include "::user_dashboard.html.twig" %}
{% endblock dashboard %}

稍后在该模板中,我想根据该块中是否有任何内容在 div 上设置一个类(即,默认情况下,它将具有上面的包含,但该模板的子级可能会覆盖它并将其清空)。

我所拥有的(有点工作)是......

{% set _dashboard = block('dashboard') %}
{% set _mainWidth = ( _dashboard|trim is empty ? "no-dashboard" : "with-dashboard" ) #}
<div id="main" class="{{ _mainWidth }}">

这里的问题是整个仪表板块被调用了两次。除了该块呈现一些控制器动作之外,这不会打扰我太多,即......

{% render "UserWidget:userAppMenu" %}

...并且该操作中的代码被调用了两次。由于各种原因,其中最重要的是性能,这与仪表板块中的一些东西混淆了。

所以,我的问题是......有没有办法在不加载两次的情况下判断该块是否为空?是否有一些非常简单的东西我错过了,或者这甚至可能吗?

谢谢!

编辑:

如果它有助于澄清事情,这是我的完整模板:

{% extends '::base.html.twig' %}

{% block layout %}

{% block header %}
    {% include "::header.html.twig" %}
{% endblock header %}

<div id="container" class="row-fluid">

    {% block dashboard %}
        {% include "::user_dashboard.html.twig" %}
    {% endblock dashboard %}

    {% set _dashboard = block('dashboard') %}
    {% set _mainWidth = ( _dashboard|trim is empty ? "no-dashboard" : "with-dashboard" ) %}  
    <div id="main" class="{{ _mainWidth }}">
        <h1 class="page-title">{% block page_title %}{% endblock %}</h1>
        {% block main_filters %}{% endblock %}

        {% if app.session.flashbag.has('message') %}
          <div class="alert alert-block alert-success">
            <ul>
                {% for flashMessage in app.session.flashbag.get('message') %}
                    <li>{{ flashMessage }}</li>
                {% endfor %}
            </ul>
          </div>
        {% endif %}

        {% if app.session.flashbag.has('warning') %}
          <div class="alert alert-block alert-success">
            <ul>
                {% for flashWarning in app.session.flashbag.get('warning') %}
                    <li>{{ flashWarning }}</li>
                {% endfor %}
            </ul>
          </div>
        {% endif %}

        {% block body %}{% endblock %}

        {% block footer %}
            {% include "::footer.html.twig" %}
        {% endblock footer %}
    </div>

</div>

{% endblock layout %}

在这里,您可以在第 11 行和第 15 行看到 - 这两行实际上似乎都包含并处理了包含的内容。

4

1 回答 1

0

那这个呢?这样,当您调用block('dashboard').

{# at top of twig #}
{% set _dashboard = block('dashboard') %}

{# where ever you include your block #}
<div>
    {{ _dashboard|raw }}
</div>

{# and your main #}
{% set _mainWidth = ( _dashboard|trim is empty ? "no-dashboard" : "with-dashboard" ) #}
<div id="main" class="{{ _mainWidth }}">
于 2013-05-21T21:40:10.523 回答