程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> FreeMarker設計指南(4) (完)

FreeMarker設計指南(4) (完)

編輯:關於JAVA

4、雜項

(1)用戶定義指令

l 宏和變換器變量是兩種不同類型的用戶定義指令,它們之間的區別是宏是在模板中使用Macro指令定義,而變換器是在模板外由程序定義,這裡只介紹宏

l 基本用法

Ø 宏是和某個變量關聯的模板片斷,以便在模板中通過用戶定義指令使用該變量,下面是一個例子:

<#Macro greet>

Hello Joe!

Ø 作為用戶定義指令使用宏變量時,使用@替代FTL標記中的#

<@greet>

Ø 如果沒有體內容,也可以使用:

<@greet/>

l 參數

Ø 在Macro指令中可以在宏變量之後定義參數,如:

<#Macro greet person>

Hello ${person}!

Ø 可以這樣使用這個宏變量:

<@greet person="Fred"/> and <@greet person="Batman"/>

輸出結果是:

Hello Fred!

and Hello Batman!

Ø 宏的參數是FTL表達式,所以下面的代碼具有不同的意思:

<@greet person=Fred/>

Ø 這意味著將Fred變量的值傳給person參數,該值不僅是字符串,還可以是其它類型,甚至是復雜的表達式

Ø 宏可以有多參數,下面是一個例子:

<#Macro greet person color>

Hello ${person}!

Ø 可以這樣使用該宏變量:

<@greet person="Fred" color="black"/>

Ø 其中參數的次序是無關的,因此下面是等價的:

<@greet color="black" person="Fred"/>

Ø 只能使用在Macro指令中定義的參數,並且對所有參數賦值,所以下面的代碼是錯誤的:

<@greet person="Fred" color="black" background="green"/>

<@greet person="Fred"/>

Ø 可以在定義參數時指定缺省值,如:

<#Macro greet person color="black">

Hello ${person}!

Ø 這樣<@greet person="Fred"/>就正確了

Ø 宏的參數是局部變量,只能在宏定義中有效

l 嵌套內容

Ø 用戶定義指令可以有嵌套內容,使用<#nested>指令執行指令開始和結束標記之間的模板片斷

Ø 例子:

<#Macro border>

<#nested>

這樣使用該宏變量:

<@border>The bordered text

輸出結果:

The bordered text

Ø <#nested>指令可以被多次調用,例如:

<#Macro do_thrice>

<#nested>

<#nested>

<#nested>

<@do_thrice>

Anything.

輸出結果:

Anything.

Anything.

Anything.

Ø 嵌套內容可以是有效的FTL,下面是一個有些復雜的例子:

<@border>

    <@do_thrice>

  • <@greet person="Joe"/>

輸出結果:

  • Hello Joe!

  • Hello Joe!

  • Hello Joe!

Ø 宏定義中的局部變量對嵌套內容是不可見的,例如:

<#Macro repeat count>

<#local y = "test">

<#list 1..count as x>

${y} ${count}/${x}: <#nested>

<@repeat count=3>${y?default("?")} ${x?default("?")} ${count?default("?")}

輸出結果:

test 3/1: ? ? ?

test 3/2: ? ? ?

test 3/3: ? ? ?

Ø

l 在宏定義中使用循環變量

Ø 用戶定義指令可以有循環變量,通常用於重復嵌套內容,基本用法是:作為nested指令的參數傳遞循環變量的實際值,而在調用用戶定義指令時,在<@…>開始標記的參數後面指定循環變量的名字

Ø 例子:

<#Macro repeat count>

<#list 1..count as x>

<#nested x, x/2, x==count>

<@repeat count=4 ; c, halfc, last>

${c}. ${halfc}<#if last> Last!

輸出結果:

1. 0.5

2. 1

3. 1.5

4. 2 Last!

Ø 指定的循環變量的數目和用戶定義指令開始標記指定的不同不會有問題

n 調用時少指定循環變量,則多指定的值不可見

n 調用時多指定循環變量,多余的循環變量不會被創建

(2)在模板中定義變量

l 在模板中定義的變量有三種類型:

Ø plain變量:可以在模板的任何地方訪問,包括使用include指令插入的模板,使用assign指令創建和替換

Ø 局部變量:在宏定義體中有效,使用local指令創建和替換

Ø 循環變量:只能存在於指令的嵌套內容,由指令(如list)自動創建;宏的參數是局部變量,而不是循環變量

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

<#assign x = "plain">

1. ${x} <#-- we see the plain var. here -->

<@test/>

6. ${x} <#-- the value of plain var. was not changed -->

<#list ["loop"] as x>

7. ${x} <#-- now the loop var. hides the plain var. -->

<#assign x = "plain2"> <#-- replace the plain var, hiding does not mater here -->

8. ${x} <#-- it still hides the plain var. -->

9. ${x} <#-- the new value of plain var. -->

<#Macro test>

2. ${x} <#-- we still see the plain var. here -->

<#local x = "local">

3. ${x} <#-- now the local var. hides it -->

<#list ["loop"] as x>

4. ${x} <#-- now the loop var. hides the local var. -->

5. ${x} <#-- now we see the local var. again -->

輸出結果:

1. plain

2. plain

3. local

4. loop

5. local

6. plain

7. loop

8. loop

9. plain2

l 內部循環變量隱藏同名的外部循環變量,如:

<#list ["loop 1"] as x>

${x}

<#list ["loop 2"] as x>

${x}

<#list ["loop 3"] as x>

${x}

${x}

${x}

輸出結果:

loop 1

loop 2

loop 3

loop 2

loop 1

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

<#assign user = "Joe Hider">

${user} <#-- prints: Joe Hider -->

${.globals.user} <#-- prints: Big Joe -->

(3)名字空間

l 通常情況,只使用一個名字空間,稱為主名字空間

l 為了創建可重用的宏、變換器或其它變量的集合(通常稱庫),必須使用多名字空間,其目的是防止同名沖突

l 創建庫

Ø 下面是一個創建庫的例子(假設保存在lib/my_test.ftl中):

<#Macro copyright date>

Copyright (C) ${date} Julia Smith. All rights reserved.


Email: ${mail}

<#assign mail = "[email protected]">

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

<#import "/lib/my_test.ftl" as my>

<#assign mail="[email protected]">

<@my.copyright date="1999-2002"/>

${my.mail}

${mail}

輸出結果:

Copyright (C) 1999-2002 Julia Smith. All rights reserved.


Email: [email protected]

[email protected]

[email protected]

可以看到例子中使用的兩個同名變量並沒有沖突,因為它們位於不同的名字空間

l 可以使用assign指令在導入的名字空間中創建或替代變量,下面是一個例子:

<#import "/lib/my_test.ftl" as my>

${my.mail}

<#assign mail="[email protected]" in my>

${my.mail}

l 輸出結果:

[email protected]

[email protected]

l 數據模型中的變量任何地方都可見,也包括不同的名字空間,下面是修改的庫:

<#Macro copyright date>

Copyright (C) ${date} ${user}. All rights reserved.

<#assign mail = "${user}@acme.com">

l 假設數據模型中的user變量的值是Fred,則下面的代碼:

<#import "/lib/my_test.ftl" as my>

<@my.copyright date="1999-2002"/>

${my.mail}

l 輸出結果:

Copyright (C) 1999-2002 Fred. All rights reserved.

[email protected]

[點擊此處收藏本文] 發表於 2004年11月17日 10:14 PM -->flylyke 發表於2004-11-19 12:48 AM 老兄,翻譯的好yny 發表於2004-12-22 12:15 PM 老兄,翻譯的好 steven 發表於2005-02-24 8:40 PM 這幾天我也在看Freemaker,我想請問一個問題, freemarker.template 下的 addMacro() 和addImport() 兩個方法是干什麼的,怎麼用,我看了半天,謝謝了

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved