2014-09-04 56 views
14

在树枝模板中,是否可以将内容追加到块中?树枝将内容追加到块

例如,请考虑下面的模板文件。

layout.html.twig

<html> 
<head> 
    <style> 
    {% block css %}{% endblock css %} 
    </style> 
</head> 
<body> 
{% block content %}{% endblock content %} 
</body> 
</html> 

inner.html.twig

{% block css %} 
a { color: #fff; } 
body { background: #f00; } 
{% endblock css %} 

{% block content %} 

Some contents here... 
{% include 'myWidget.html.twig' %} 

{% endblock content %} 

myWidget.html.twig

{% block css %} 
div a { color: #777; } 
{% endblock css %} 
{% block content %} 
<div><a>myWidget content here...</a></div> 
{% endblock content %} 

声明块的CSS ..我试图要完成的是我希望块的CSS每个内容附加到layout.html.twig的CSS块。因此,最终的结果应该是:

<html> 
<head> 
    <style> 
    a { color: #fff; } 
    body { background: #f00; } 
    div a { color: #777; } 
    </style> 
</head> 
<body> 
Some contents here... 
<div><a>myWidget content here...</a></div> 
</body> 
</html> 

回答

21

这应该做的伎俩:

{% block css %} 
    {{ parent() }} 
    div a { color: #777; } 
{% endblock css %} 

{% block content %} 
    <div><a>myWidget content here...</a></div> 
{% endblock content %} 
+0

我会尝试这个,当我回家..谢谢@jperovic – Aldee 2014-09-04 07:49:08

2

快捷方式到附加/添加内容到块具有很少的内容,例如一个PAGETITLE

base.html.twig

... 
<title>{% block title %}MyApp{% endblock %}</title> 
... 

模板扩展基地布局

{% extends '::base.html.twig' %} 
{% block title 'Page1 - '~parent() %} {# prepend #} 
{% block title parent()~' - Page1' %} {# append #}