Twig is a template engine for PHP. It is used by Drupal to render HTML pages.
Twig is a very powerful tool that allows you to create complex templates with very little code.
Accessing variables
It is recommended to use the dot (.) syntax to access variables.
{{ variable['key'] }} {# This is allowed, but use {{ variable.key }} instead! #}{{ variable[0] }} {# This is allowed, but use {{ variable.0 instead! }} #}
Loops
Using if conditions in loops:
You can limit the items returned in an iteration by adding an if clause. The example below will loop over all rows of the items variable, but only print out those where item.status evaluates to TRUE.
{%for item in items if item.status %} {{ item.title }}{%endfor%}
Arguments to filters can be named, so that a filter can be used without specifying a value for all arguments. This is useful when using filters like round, which takes two arguments: round(precision, method). Perhaps you only want to specify a value for the second argument and want to leave the first one as default. Writing your function like the example can make your templates more readable.
<div>{{ 3.14159|round(method="ceil") }}</div>
Check if variable is not null
{%if foo is not null and foo is not empty %}{%if foo|length %}
## Nodes
Render Node elements and fields
{# Node Title #}{{node.getTitle()}}{# Image Field #}{{ file_url(node.field_name.entity.fileuri) }} // Url{{node.field_name.entity.alt.value}} // Alt{# Normal field Value #}{{node.field_name.value}}{{node.field_name.value|raw}} // Raw Value{# Date Field #}{{ node.field_name.value |date("d/m/Y") }}{{ file_url(node.field_name[key].entity.uri.value) }}{{ node.field_name[key].alt }}
Render Referenced Media Elements
{# Media element = Image #}{% set IMAGEURL = node.FIELD_NAME.entity.MEDIA_FIELD_NAME|file_uri %}{% set IMAGEALT = node.FIELD_NAME.entity.MEDIA_FIELD_NAME.entity.field_media_image.alt %}{{ file_url(IMAGEURL)}}{{ IMAGEALT }}{# Using Twig tweak #}{{ drupal_entity('media', node.FIELD_NAME.entity.MEDIA_FIELD_NAME.entity.id) }}
Render multiple field elements
// Loop through multiple items in a field, for example tags{%for item in content.field_tags|children %}<p>{{ item }}</p>{%endfor%}{%for element in testArray %} {{ element.someString }},{%endfor%}{%for role in user.roles %} {{ role.name }} {%if not loop.last %},{%endif%}{%endfor%}
Render/Access List (Text) Field type
{{node.field_name[0].value}}
Render the label of a select field type
{%for key, item in NODE.CONTENT_TYPE.entity.FIELD_NAME if key|first !='#'%} {% set VALUE = item.value %} {{ NODE.CONTENT_TYPE.entity.FIELD_NAME.getSetting('allowed_values')[VALUE] }}{%endfor%}
Taxonomies
Render multiple taxonomy terms field
// Core Method{%if content.field_type_of_action %} {%for item in content.field_type_of_action['#items'] %} {{item.entity.tid.value}} {{item.entity.name.value}} {%endfor%}{%endif%}// Using Twig Tweak{% set tid = node.field_type_of_action.target_id %}{%if tid %} {{ drupal_field('name','taxonomy_term', tid) }} {%endif%}
Render Translated content types or Taxonomies
// THEMENAME.theme or MODULENAME.moduleTHEME_NAME_PREPROCESS_NODE(&variables){$language =\Drupal::languageManager()->getCurrentLanguage()->getId();variables['language'] = $language; // We export the 'language' variable so that it can be accessed in the twig file}// Twig File{%for item in content.FIELD_NAME['#items'] %} {{item.entity.TRANSLATION(LANGUAGE).name.value}}{%endfor%}// This Works for field values{{node.translation(LANGUAGE).body.value}}
Reference
For more information about Twig, see the Twig documentation. Also here are some useful links that can help you to understand how to use Twig in Drupal 8/9: