Twig

The flexible, fast, and secure
template engine for PHP

a Symfony Product
Docs Coding Standards
You are reading the documentation for Twig 2.x. Switch to the documentation for Twig 1.x. 3.x.
Warning Twig version 2.x end of maintenance is scheduled for December 2023.

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