我有一个带有以下块的树枝模板:
{% 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 行看到 - 这两行实际上似乎都包含并处理了包含的内容。