Twig

The flexible, fast, and secure
template engine for PHP

a Symfony Product
You are reading the documentation for Twig 2.x. Switch to the documentation for Twig 1.x. 3.x.

Questions & Feedback

License

Twig documentation is licensed under the new BSD license.

Coding StandardsΒΆ

When writing Twig templates, we recommend you to follow these official coding standards:

  • Put one (and only one) space after the start of a delimiter ({{, {%, and {#) and before the end of a delimiter (}}, %}, and #}):

    1
    2
    3
    {{ foo }}
    {# comment #}
    {% if foo %}{% endif %}
    

    When using the whitespace control character, do not put any spaces between it and the delimiter:

    1
    2
    3
    {{- foo -}}
    {#- comment -#}
    {%- if foo -%}{%- endif -%}
    
  • Put one (and only one) space before and after the following operators: comparison operators (==, !=, <, >, >=, <=), math operators (+, -, /, *, %, //, **), logic operators (not, and, or), ~, is, in, and the ternary operator (?:):

    1
    2
    3
    {{ 1 + 2 }}
    {{ foo ~ bar }}
    {{ true ? true : false }}
    
  • Put one (and only one) space after the : sign in hashes and , in arrays and hashes:

    1
    2
    {{ [1, 2, 3] }}
    {{ {'foo': 'bar'} }}
    
  • Do not put any spaces after an opening parenthesis and before a closing parenthesis in expressions:

    1
    {{ 1 + (2 * 3) }}
    
  • Do not put any spaces before and after string delimiters:

    1
    2
    {{ 'foo' }}
    {{ "foo" }}
    
  • Do not put any spaces before and after the following operators: |, ., .., []:

    1
    2
    3
    4
    {{ foo|upper|lower }}
    {{ user.name }}
    {{ user[name] }}
    {% for i in 1..12 %}{% endfor %}
    
  • Do not put any spaces before and after the parenthesis used for filter and function calls:

    1
    2
    {{ foo|default('foo') }}
    {{ range(1..10) }}
    
  • Do not put any spaces before and after the opening and the closing of arrays and hashes:

    1
    2
    {{ [1, 2, 3] }}
    {{ {'foo': 'bar'} }}
    
  • Use lower cased and underscored variable names:

    1
    2
    {% set foo = 'foo' %}
    {% set foo_bar = 'foo' %}
    
  • Indent your code inside tags (use the same indentation as the one used for the target language of the rendered template):

    1
    2
    3
    4
    5
    {% block foo %}
        {% if true %}
            true
        {% endif %}
    {% endblock %}
    
Website powered by Symfony and Twig, deployed on
The Twig logo is © 2010-2020 Symfony