隨筆-18  評(píng)論-8  文章-0  trackbacks-0

          FreeMarker是一個(gè)用Java編寫的模板引擎,主要用來生成HTML Web頁面,特別是基于MVC模式的應(yīng)用程序。雖然FreeMarker具有一些編程的能力,但不像PHP,通常由Java程序準(zhǔn)備要顯示的數(shù)據(jù),由FreeMarker模板生成頁面。  FreeMarker可以作為Web應(yīng)用框架一個(gè)組件,但它與容器無關(guān),在非Web應(yīng)用程序環(huán)境也能工作的很好。 FreeMarker適合作為MVC的視圖組件,還能在模板中使用JSP標(biāo)記庫。

          <html>
          <head>
            
          <title>Welcome!</title>
          </head>
          <body>
            
          <h1>Welcome ${user}!</h1>
            
          <p>Our latest product:
            
          <href="${latestProduct.url}">${latestProduct.name}</a>!
          </body>
          </html>  

          上面的例子中,在簡單的HTML中加入了一些由${…}包圍的特定FreeMarker的指令,這個(gè)文件就稱為模板了。而user、latestProduct.url和latestProduct.name來自于數(shù)據(jù)模型,由Java程序提供,模板設(shè)計(jì)者就不用關(guān)心數(shù)據(jù)從哪來的。

          FreeMarker模板中可以包括下面四種特定部分:
          一.) 文本:直接輸出
          二.) FTL標(biāo)記(FreeMarker模板語言標(biāo)記):類似于HTML標(biāo)記,名字前加#(有些以@開始,用戶自定義標(biāo)記)予以區(qū)分,不會(huì)輸出。
          字符串- 使用單引號(hào)或雙引號(hào)限定;如果包含特殊字符需要轉(zhuǎn)義符:${"It's \"quoted\" andthis is a backslash: \\"}
          有一類特殊的字符串:${r"C:\foo\bar"},輸出結(jié)構(gòu)為:C:\foo\bar,在引號(hào)前面加r被認(rèn)為是純文本。
          數(shù)字-直接輸入,不需要引號(hào)。${08}, ${+8}, ${8.00} and ${8} 都是相同的
          布爾值-true和false,不使用引號(hào)
          Sequences(序列)-由逗號(hào)分隔的變量列表,由方括號(hào)限定,類似java中的一維數(shù)組:

          <#list ["winter", "spring", "summer", "autumn"] as x>
          ${x}
          </#list>

          輸出結(jié)果:
          winter
          spring
          summer
          autumn

          例二:[2 + 2, [1, 2, 3, 4], "whatnot"]
          例三:2..5,等同于[2, 3, 4, 5];5..2,等同于[5,4,3,2]。注意方括號(hào)是不需要的。

          Hashes(散列)-由逗號(hào)分隔的鍵-值列表,由大括號(hào)限定,鍵和值之間用冒號(hào)分隔:{"name":"green mouse", "price":150},鍵和值都是表達(dá)式,但是鍵必須是字符串。

          獲取變量-${variable},變量名只能是字母、數(shù)字、下劃線、$、@和#的組合,且不能以數(shù)字開頭。下列表達(dá)式是等價(jià)的:
          book.author.name
          book["author"].name
          book.author.["name"]
          book["author"]["name"]

          獲取Sequence(序列)片斷-使用[startindex..endindex],例如:seq中存儲(chǔ)了"a", "b", "c", "d","e",那么seq[1..2]包含了b和c兩個(gè)值。

          可以使用.variablename語法訪問FreeMarker內(nèi)置變量。

          字符串操作
          {"Hello ${user}!"} <==> ${"Hello " + user + "!"}
          ${"${user}${user}${user}${user}"} <==> ${user + user + user + user}

          ${…}只能在文本中使用,下面是錯(cuò)誤的代碼:
          <#if ${isBig}>Wow!</#if>
          <#if "${isBig}">Wow!</#if>  //此處的代碼也是錯(cuò)誤的,因?yàn)閕f指令需要的是boolean,實(shí)際的卻是個(gè)字符串

          子字符串的操作,假設(shè)user的值為"Big Joe":
          ${user[0]}${user[4]}  <==>  BJ
          ${user[1..4]}  <==> ig J

          Sequences(序列)操作

          <#list ["Joe", "Fred"] + ["Julia", "Kate"] as user>
          - ${user}
          </#list>

          結(jié)果:
          - Joe
          - Fred
          - Julia
          - Kate

          Hashes(散列)操作

          <#assign ages {"Joe":23, "Fred":25} + {"Joe":30, "Julia":18}>
          - Joe is ${ages.Joe}
          - Fred is ${ages.Fred}
          - Julia is ${ages.Julia}  

          結(jié)果:
          - Joe is 30
          - Fred is 25
          - Julia is 18 

          算術(shù)運(yùn)算

          <#-- x的值設(shè)定為5 -->
          ${x * x - 100}
          ${x / 2}
          ${12 % 10}

          結(jié)果:
          -75
          2.5
          2

          注意: 操作符兩邊必須是數(shù)字;使用"+"時(shí),如果一邊是數(shù)字,一邊是字符串,就會(huì)自動(dòng)將數(shù)字轉(zhuǎn)換為字符串。

          使用內(nèi)建的指令int獲得整數(shù)部分

          ${(x/2)?int}
          ${1.1?int}
          ${1.999?int}
          ${-1.1?int}
          ${-1.999?int}

          結(jié)果:
          2
          1
          1
          -1
          -1

          比較操作符-<#if expression>...</#if>
          1.)使用=(或==,完全相等)測試兩個(gè)值是否相等,使用!= 測試兩個(gè)值是否不相等
          2.)=和!=兩邊必須是相同類型的值,否則會(huì)產(chǎn)生錯(cuò)誤,例如<#if 1 = "1">會(huì)引起錯(cuò)誤
          3.)Freemarker是精確比較,所以"x"、"x  "和"X"是不相等的
          4.)對(duì)數(shù)字和日期可以使用<、<=、>和>=,但不能用于字符串
          5.)由于Freemarker會(huì)將>解釋成FTL標(biāo)記的結(jié)束字符,所以對(duì)于>和>=可以使用括號(hào)來避免這種情況,例如<#if (x > y)>,另一種替代的方法是,使用lt、lte、gt和gte來替代<、<=、>和>=

          邏輯操作符-&&(and)、||(or)、!(not),只能用于布爾值,否則會(huì)產(chǎn)生錯(cuò)誤
          <#if x < 12 && color = "green">
            We have less than 12 things, and they are green.
          </#if>
          <#if !hot> <#-- here hot must be a boolean -->
            It's not hot.
          </#if> 

          內(nèi)置函數(shù)-用法類似訪問hash(散列)的子變量,只是使用"?"替代".",例如:user?upper_case
          下面列出常用的一些函數(shù):
          對(duì)于字符串
          html-對(duì)字符串進(jìn)行HTML編碼
          cap_first-使字符串第一個(gè)字母大寫
          lower_case-將字符串轉(zhuǎn)換成小寫
          trim-去掉字符串前后的空白字符
          對(duì)于Sequences(序列)
          size-獲得序列中元素的數(shù)目
          對(duì)于數(shù)字
          int-取得數(shù)字的整數(shù)部分(如-1.9?int的結(jié)果是-1)

          例一:

          <#-- test的值為Tom & Jerry -->
          ${test?html}
          ${test?upper_case?html}

          結(jié)果:
          Tom &amp; Jerry
          TOM &amp; JERRY

          例二:

          <#-- seasons的值為"winter", "spring", "summer", "autumn" --> 
          ${seasons?size}
          ${seasons[1]?cap_first} 
          <#-- left side can by any expression -->
          ${"horse"?cap_first}  

          結(jié)果:
          4
          Spring
          Horse 

          方法的調(diào)用
          ${repeat("What", 3)}
          ${repeat(repeat("x", 2), 3) + repeat("What", 4)?upper_case}
          結(jié)果:
          WhatWhatWhat
          xxxxxxWHATWHATWHATWHAT

          操作符優(yōu)先順序
          后綴            [subvarName] [subStringRange] . (methodParams)
          一元            +expr、-expr、!
          內(nèi)建            ?
          乘法            *、 / 、%
          加法            +、-
          關(guān)系            <、>、<=、>=(lt、lte、gt、gte)
          相等            =、!=
          邏輯            &&
          邏輯            ||
          數(shù)字范圍      ..

          三.) Interpolation:由${...}或#{...}兩種類型,輸出計(jì)算值,可以定義輸出的格式
          例一:

          <#setting number_format="currency"/>
          <#assign answer=42/>
          ${answer}
          ${answer?string}  <#-- the same as ${answer} --
          >
          ${answer?string.number}
          ${answer?string.currency}
          ${answer?string.percent} 

          結(jié)果:
          $42.00
          $42.00
          42
          $42.00
          4,200%

          例二:

          ${lastUpdated?string("yyyy-MM-dd HH:mm:ss zzzz")}
          ${lastUpdated?string("EEE, MMM d, ''yy")}
          ${lastUpdated?string("EEEE, MMMM dd, yyyy, hh:mm:ss a '('zzz')'")}  

          結(jié)果:
          2003-04-08 21:24:44 Pacific Daylight Time
          Tue, Apr 8, '03
          Tuesday, April 08, 2003, 09:24:44 PM (PDT)

          例三:

          <#assign foo=true/>
          ${foo?string("yes", "no")}

          結(jié)果:
          yes

          例四:

          <#-- x is 2.582 and y is 4 -->
          #{x; M2}   
          <#-- 2.58 -->
          #{y; M2}   
          <#--    -->
          #{x; m1}   
          <#-- 2.6 -->
          #{y; m1}   
          <#-- 4.0 -->
          #{x; m1M2} 
          <#-- 2.58 -->
          #{y; m1M2} 
          <#-- 4.0  -->  

          說明:mX-小數(shù)部分最小X位;MX-小數(shù)部分最大X位。

          四.) 注釋:<#--和-->

          下面是一個(gè)常用的模板例子:

          <p>We have these animals:
          <table border=1>
            
          <tr><th>Name<th>Price
            
          <#list animals as being>
            
          <tr>
              
          <td>
                
          <#if being.size = "large"><b></#if>
                ${being.name}
                
          <#if being.size="large"></b></#if>
              
          <td>${being.price} Euros
            
          </#list>
           
          </table> 
          <#include "/copyright_footer.html">

          注意點(diǎn)
          1.) FreeMarker是區(qū)分大小寫的;
          2.) FTL標(biāo)記不能位于另一個(gè)FTL標(biāo)記內(nèi)部,例如:<#if <#include 'foo'>='bar'>...</if>;
          3.) ${…}只能在文本中使用;
          4.) 多余的空白字符會(huì)在模板輸出時(shí)去除;
          5.) 如果使用的指令不存在,會(huì)產(chǎn)生一個(gè)錯(cuò)誤消息。


          參考:   
                       
          FreeMarker  in sourceforge.net

          posted on 2005-03-11 11:00 阿姆斯壯 閱讀(8759) 評(píng)論(3)  編輯  收藏 所屬分類: 工具箱

          評(píng)論:
          # re: 學(xué)習(xí)FreeMarker(一) 2005-12-20 22:01 | clarence
          怎么都是這些例子啊,有沒有難點(diǎn)的事例啊  回復(fù)  更多評(píng)論
            
          # re: 學(xué)習(xí)FreeMarker(一) 2006-08-23 17:48 | zizhu
          還有沒有學(xué)習(xí)FreeMarker(二)及其系列?  回復(fù)  更多評(píng)論
            
          # re: 學(xué)習(xí)FreeMarker(一) 2006-09-01 15:57 | 歐陽
          是啊,在深入一點(diǎn)啊,
          讓我們能更多得了解freemarker,
          謝謝斑竹啊,歡迎咄咄發(fā)表,  回復(fù)  更多評(píng)論
            

          只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 庆云县| 依兰县| 铜山县| 海伦市| 旌德县| 东港市| 华坪县| 双牌县| 平昌县| 买车| 河西区| 德清县| 开封市| 内黄县| 菏泽市| 怀宁县| 赤城县| 论坛| 墨竹工卡县| 扶绥县| 罗平县| 南漳县| 漯河市| 彰化市| 会同县| 栖霞市| 香格里拉县| 蒲江县| 平泉县| 青州市| 乐至县| 石河子市| 延津县| 威信县| 页游| 星座| 大同县| 新巴尔虎左旗| 桑植县| 德州市| 炎陵县|