用戶定義指令-使用@符合來調用
有兩種不同的類型:Macro(宏)和transform(傳遞器),Macro是在模板中使用macro指令定義,而transform是在模板外由程序定義(基本上都是基于Java的),這里通過Macro來介紹自定義指令。
例一:
<#macro greet>
<font size="+2">Hello Joe!</font>
</#macro>
使用:<@greet></@greet> 或 <@greet/>
結果:<font size="+2">Hello Joe!</font>
參數-在macro指令中可以在宏變量之后定義參數
例二:
<#macro greet person>
<font size="+2">Hello ${person}!</font>
</#macro>
使用:<@greet person="Fred"/> and <@greet person="Batman"/>
結果: <font size="+2">Hello Fred!</font> and <font size="+2">Hello Batman!</font>
macro可以有多個參數,參數的次序是無關的,在macro指令中只能使用定義的參數,并且必須對所有參數賦值,可以在定義參數時指定缺省值:




在自定義指令嵌套內容:模板片斷中使用<#nested>指令





使用:<@border>The bordered text</@border>
結果:



<#nested>指令可以被多次調用:





使用:
<@do_thrice>Anything.</@do_thrice>
結果:
Anything.
Anything.
Anything.
注意:嵌套內容是無法訪問到macro中的局部變量的。
例如:







結果:
test 3/1: ? ? ?
test 3/2: ? ? ?
test 3/3: ? ? ?
下面是一個嵌套使用自定義指令的例子:







結果:







在macro中使用循環變量-作為nested指令的參數傳遞循環變量的實際值,而在調用用戶定義指令時,在<@…>開始標記的參數后面指定循環變量的名字:








結果:
1. 0.5
2. 1
3. 1.5
4. 2 Last!
注意:循環變量和用戶定義指令開始標記指定的數目可以不同,調用時少指定循環變量,則多指定的值不可見,調用時多指定循環變量,多余的循環變量不會被創建。
模板中的變量,有三種類型:
1.) plain(全局)變量:可以在模板的任何地方訪問,包括使用include指令插入的模板,使用assign指令創建和替換
2.) 局部變量:在macro中有效,使用local指令創建和替換
3.) 循環變量:只能存在于指令的嵌套內容,由指令(如list)自動創建;宏的參數是局部變量,而不是循環變量
用assign指令創建和替換的例子:




結果:
1
4
局部變量隱藏(而不是覆蓋)同名的plain變量;循環變量隱藏同名的局部變量和plain變量,下面是一個例子:




















結果:
1. plain
2. plain
3. local
4. loop
5. local
6. plain
7. loop
8. loop
9. plain2
內部循環變量隱藏同名的外部循環變量,例如:











結果:
loop 1
loop 2
loop 3
loop 2
loop 1
模板中的變量會隱藏(而不是覆蓋)數據模型中同名變量,如果需要訪問數據模型中的同名變量,使用特殊變量global,下面的例子假設數據模型中的user的值是Big Joe:



命名(namespaces)空間-通常情況,只使用一個命名空間,稱為主命名空間(main namespace),但你是不會意識到這些的;為了創建可重用的macro、transforms或其它變量的集合(通常稱庫),必須使用多命名空間,為了防止同名沖突。
首先創建一個庫(假設保存在lib/my_test.ftl中):





使用import指令導入庫到模板中,Freemarker會為導入的庫創建新的命名空間,并可以通過import指令中指定的hash(散列)變量訪問庫中的變量:





結果:




上面的例子中使用的兩個同名變量并沒有沖突,因為它們位于不同的命名空間
可以使用assign指令在導入的命名空間中創建或替代變量:




結果:
jsmith@acme.com
jsmith@other.com
數據模型中的變量任何地方都可見,也包括不同的命名空間,下面修改了剛才創建的庫:




假設數據模型中的user變量的值是Fred:



結果:
<p>Copyright (C) 1999-2002 Fred. All rights reserved.</p>
Fred@acme.com
參考:
FreeMarker in sourceforge.net