Directives
You use FTL tags to call directives. In the example you have called the list
directive. Syntactically you have done it with two tags: <#list animals as animal>
and </#list>
.
There are two kind of FTL tags:
-
Start-tag:
<#directivename parameters>
-
End-tag:
</#directivename>
This is similar to HTML or XML syntax, except that the tag name starts with #
. If the directive doesn’t have nested content (content between the start-tag and the end-tag), you must use the start-tag with no end-tag. For example you write <#if something>...</#if>
, but just <#include something>
as FreeMarker knows that the include directive can’t have nested content.
The format of the parameters depends on the directive name.
In fact there are two types of directives: predefined directives and user-defined directives. For user-defined directives you use @
instead of #
, for example <@mydirective parameters>...</@mydirective>
. Further difference is that if the directive has no nested content, you must use a tag like <@mydirective parameters />
, similarly as in XML (e.g. <img ... />
). But user-defined directives is an advanced topic that will be discussed later.
FTL tags, like HTML tags, must be properly nested. So the code below is wrong, as the if directive is both inside and outside of the nested content of the list
directive:
Note that FreeMarker doesn’t care about the nesting of HTML tags, only about the nesting of FTL tags. It just sees HTML as flat text, it doesn’t interpret it in any way.
If you try to use a non-existing directive (e.g., you mistype the directive name), FreeMarker will decline to use the template and produce an error message.
FreeMarker ignores superfluous white-space inside FTL tags. So you can write this:
<#list animals as animal > ${animal.name} for ${animal.price} Euros </#list >
You may not, however, insert white-space between the <
or </
and the directive name.
The complete list and description of all directives can be found in the Directive Reference (but I recommend that you look at the chapter about expressions first).