Twig | |
---|---|
Original author(s) | Armin Ronacher, [1] Fabien Potencier |
Developer(s) | Symfony SAS |
Initial release | October 12, 2009 |
Stable release | 3.21.1 [2] / 3 May 2025 |
Repository | |
Written in | PHP |
Operating system | Cross-platform |
Type | Template engine |
License | BSD License |
Website | twig |
Twig is a template engine for the PHP programming language. Its syntax originates from Jinja and Django templates. [3] It's an open source product [4] licensed under a BSD License and maintained by Fabien Potencier. The initial version was created by Armin Ronacher. Symfony PHP framework comes with a bundled support for Twig as its default template engine since version 2. [5]
The same template language is used by the Nunjucks template engine, thus Nunjucks is also supported by the following tools.
Twig is supported by the following integrated development environments: [3]
And the text editors:
Twig defines three kinds of delimiters:
{{ ... }}
, to print the content of variables or the result of evaluating an expression (e.g.: an inherited Twig template with {{ parent() }}
).{# ... #}
, to add comments in the templates. These comments aren't included in the rendered page.{% ... %}
, to execute statements, such as for-loops. {%setfoo='bar'%}
, to assign. [8] {%ifiisdefinedandi==1%} ... {%endif%}
: condition.{%foriin0..10%} ... {%endfor%}
: counter in a loop.The apostrophe (') is the escape character.
To create an iterative array:
{%setmyArray=[1,2]%}
An associative array:
{%setmyArray={'key':'value'}%}
The operators precedence is, [3] from the less to more priority:
Operator | Role |
---|---|
b-and | Bitwise AND |
b-xor | Bitwise XOR |
b-or | Bitwise OR |
or | Or |
and | And |
== | Is equal? |
!= | Is different? |
< | Inferior |
> | Superior |
>= | Superior or equal |
<= | Inferior or equal |
in | Into |
matches | Corresponds |
starts with | Begins by |
ends with | Finishes by |
.. | Sequence (ex: 1..5 ) |
+ | Plus |
- | Less |
~ | Concatenation |
* | Multiplication |
/ | Division |
// | Division rounded to lower |
% | Modulo |
is | Test (ex: is defined or is not empty ) |
** | Power |
| | Filter [6] |
[] | Array entry |
. | Attribute or method from an object (ex: country.name ) |
The filters provide some treatments on an expression, when placed after it, separated by pipes. For example: [6]
capitalize
: changes a string's first letter to capital.upper
: changes a whole string to capital.first
: displays the first line of an array.length
: returns a variable size.loop
contains the current loop information. For example loop.index
corresponds to the number of iterations which have already occurred.{{ path(app.request.attributes.get('_route'), app.request.attributes.get('_route_params')) }}
{{ app.request.server.get('SERVER_NAME') }}
.The example below demonstrates some basic features of Twig.
{%extends"base.html"%}{%blocknavigation%}<ulid="navigation">{%foriteminnavigation%}<li><ahref="{{item.href}}">{%ifitem.level==2%} {%endif%}{{item.caption|upper}}</a></li>{%endfor%}</ul>{%endblocknavigation%}
Twig has become a widely adopted templating engine in the PHP ecosystem. It is the default templating language for the Symfony framework and is also integrated into several content management systems (CMS) and applications, including:
Twig is also employed in many custom PHP applications where secure and readable templating are important. The similarity of Twig to Jinja and Django templates has also made it familiar to developers coming from Python and other similar ecosystems.