Twig Variables
Variables are the primary way that you output data in templates.
You use the output tags to display a variable.
{{ variableName }}
The curly braces are not part of the variable. They are the output tags that tell the template engine to output the variable. When accessing variables inside tags, don't put the braces around them. For example when assigning a value to a variable from another variable:
{% set newVar = otherVariable ~ ' some string to add on.' %}
Variables can have a simple name like {{ header }} and hold a string value.
Or, variables can represent an array of data like the {{ post }} variable above. The {{ post }} variable represents an array of data, and content is just one value in that array. If the variable is an array, then you access values in the array using the dot syntax. For example:
If the variable is an array or HTML object, you can access values in the array or object using the dot (.) syntax.
{{ item.itemName }}
Here is an example variable using a blog post for our data set.
{{ post.content }}
{{ post.abstract }}
{{ post.postTitle }}
If the array/object key contains special characters (like "-" that would be interpreted as the minus operator) then use the attribute function instead to access the value.
{{ attribute(item, 'data-foo') }}
If the variable you're trying to access doesn't exist, then nothing is displayed. That even applies if you are using a filter on a non-existent variable.
We've taken Twig variables beyond an array and in a lot of cases what looks like an array is actually a data object that we call HTML Objects. This gives you superpowers as a developer and it allows you to manipulate data before it's used.
For example, if your data represents an image and its HTML tag, you can manipulate the image tag data before it's displayed. You can even add custom attributes to the image tag.
In the example below we will check and see if the alt text is set for the image, and if not, set it before outputting the image tag.
{% if image.alt|length == 0 %}
{% set image.alt = 'My custom alt text' %}
{% endif %}
{{ image.tag }}
You can also modify variable values by using filters. For example, to convert a string to be camel-cased you can use the camel filter.
{{ post.postTitle|camel }}
Using a variable as an object key
If you're trying to use a variable as an object key, then you need to wrap the variable in parentheses.
Wrong:
{% set data = data|merge({variableName: 'value'}) %}
Correct:
{% set data = data|merge({(variableName): 'value'}) %}
Setting variable values
You assign values to variables using the set logic tag.
{% set myName = 'Eric' %}
{% set fruit = ['apples', 'oranges'] %}
{% set location = {'city': 'Rome', 'country': 'Italy'} %}
Where do the variables come from?
There are two types of variables that you will use in your template.
- Page/app-specific variables
- Global variables
Variables that are specific to a page or an app are set in the context of that app, page, or item. Some examples include:
- Block field variables are only available in the template for that Block.
- Form field variables are only available in the template for the form that the field is part of.
- Blog post variables are only available within the Blog app, while Store product variables are only available within the Store app.
Global variables are available in either all or most templates across your entire site. We'll discuss them in more detail next.
Global variables
You can easily identify global variables in templates because they start with an underscore ( _ ). For example:
{{ _page.title }}
{{ _page.content('sidebar') }}
{{ _core.settings.companyName }}
{{ _core.date.year }}
{{ _page.cookies.cookieName }}
There are four types of global variables.
- API calls. These start with _api.
- Core variables. These start with _core.
- Page variables. These start with _page.
- Built-in Twig global variables
API variables
These are sort of like variables because they could be used to output a single value, but typically they are a way to retrieve data from another section of your website. We call them API variables because they make an API-like call internally to either:
- get data from another section of a site
- set or update data in another section of the site
- display data from another section of a site
Learn more about making API calls.
A few simple examples include:
- Displaying a form on a page.
- Retrieving recent blog posts to display on a home page.
- Displaying store categories in the sidebar of a product page.
Core variables
Core variables hold data that is not page-specific and can be used in nearly all templates.
Page variables
Page variables hold data that is specific to a page. For example, the SEO title for the page. See the Page Object section for more information.
Built-in Twig global variables
The following built-in Twig global variables are available to all templates.
- _charset: This references the current charset. It will always be "UTF-8".
- _context: This refers to the current context of the templates. It holds all of the variables and their values that the template has access to.
- _self: This references the current template name without the file extension.