2014-09-04 4 views
14

Nel modello di ramoscello, è possibile aggiungere il contenuto a un blocco?Twig Aggiungi contenuto al blocco

Ad esempio, considerare i file modello di seguito.

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 %} 

Avviso css blocco .. Quello che sto cercando per realizzare è che voglio avere ogni contenuto del blocco css aggiunto al blocco css del layout.html.twig. Pertanto, il risultato finale dovrebbe essere:

<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> 

risposta

21

Questo dovrebbe fare il trucco:

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

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

Proverò questo quando torno a casa .. grazie @jperovic – Aldee

2

scorciatoia per aggiungere contenuti/anteporre a blocchi con alcuni contenuti, ad esempio un pagetitle

base.html.twig

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

layout del modello di base che si estende

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