FreeMarker中文手册 – 获取变量

阿超 发表于 2009-08-29 14:58 | 来源: | 阅读 533 次

l        获取变量

        顶层变量: ${variable},变量名只能是字母、数字、下划线、$、@和#的组合,且不能以数字开头

        从散列中获取数据

        可以使用点语法或方括号语法,假设有下面的数据模型:

(root)
|
+- book
|   |
|   +- title = "Breeding green mouses"
|   |
|   +- author
|       |
|       +- name = "Julia Smith"
|       |
|       +- info = "Biologist, 1923-1985, Canada"
|
+- test = "title" 

下面都是等价的:

book.author.name
book["author"].name
book.author.["name"]
book["author"]["name"]

         使用点语法,变量名字有顶层变量一样的限制,但方括号语法没有该限制,因为名字是任意表达式的结果

         从序列获得数据:和散列的方括号语法语法一样,只是方括号中的表达式值必须是数字;注意:第一个项目的索引是0

        序列片断:使用[startIndex..endIndex]语法,从序列中获得序列片断(也是序列);startIndex和endIndex是结果为数字的表达式

         特殊变量:FreeMarker内定义变量,使用.variablename语法访问

l         字符串操作

         Interpolation(或连接操作)

        可以使用${..}(或#{..})在文本部分插入表达式的值,例如:

${"Hello ${user}!"}
${"${user}${user}${user}${user}"} 

         可以使用+操作符获得同样的结果

${"Hello " + user + "!"}
${user + user + user + user}

         ${..}只能用于文本部分,下面的代码是错误的:

<#if ${isBig}>Wow!</#if>
<#if "${isBig}">Wow!</#if>

应该写成:

<#if isBig>Wow!</#if>

        子串

        例子(假设user的值为“Big Joe”):

${user[0]}${user[4]}
${user[1..4]}

结果是(注意第一个字符的索引是0):

BJ
ig J 

l         序列操作

         连接操作:和字符串一样,使用+,下面是一个例子:

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

输出结果是:

- Joe
- Fred
- Julia
- Kate

l         散列操作

         连接操作:和字符串一样,使用+,如果具有相同的key,右边的值替代左边的值,例如:

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

输出结果是:

- Joe is 30
- Fred is 25
- Julia is 18 

l         算术运算

         +、-、×、/、%,下面是一个例子:

${x * x - 100}
${x / 2}
${12 % 10}

输出结果是(假设x为5):

-75
2.5
2 

         操作符两边必须是数字,因此下面的代码是错误的:

${3 * "5"} <#-- WRONG! --> 

        使用+操作符时,如果一边是数字,一边是字符串,就会自动将数字转换为字符串,例如:

${3 + "5"} 

输出结果是:

35

        使用内建的int(后面讲述)获得整数部分,例如:

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

输出结果是(假设x为5):

2
1
1
-1
-1

l         比较操作符

        使用=(或==,完全相等)测试两个值是否相等,使用!= 测试两个值是否不相等

        =和!=两边必须是相同类型的值,否则会产生错误,例如<#if 1 = "1">会引起错误

        Freemarker是精确比较,所以对"x"、"x "和"X"是不相等的

        对数字和日期可以使用<、<=、>和>=,但不能用于字符串

        由于Freemarker会将>解释成FTL标记的结束字符,所以对于>和>=可以使用括号来避免这种情况,例如<#if (x > y)>

        另一种替代的方法是,使用lt、lte、gt和gte来替代<、<=、>和>=

l         逻辑操作符

        &&(and)、||(or)、!(not),只能用于布尔值,否则会产生错误

       例子:

<#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> 

l         内建函数

         内建函数的用法类似访问散列的子变量,只是使用“?”替代“.”,下面列出常用的一些函数

        字符串使用的:

         html:对字符串进行HTML编码

         cap_first:使字符串第一个字母大写

         lower_case:将字符串转换成小写

         upper_case:将字符串转换成大写

         trim:去掉字符串前后的空白字符

         序列使用的:

         size:获得序列中元素的数目

         数字使用的:

         int:取得数字的整数部分(如-1.9?int的结果是-1)

         例子(假设test保存字符串"Tom & Jerry"):

${test?html}
${test?upper_case?html}

输出结果是:

Tom &amp; Jerry
TOM &amp; JERRY 

l         操作符优先顺序

操作符组

操作符

后缀

[subvarName] [subStringRange] . (methodParams)

一元

+expr、-expr、!

内建

?

乘法

*、 / 、%

加法

+、-

关系

<、>、<=、>=(lt、lte、gt、gte)

相等

==(=)、!=

逻辑and

&&

逻辑or

||

数字范围

..

4Interpolation

l         Interpolation有两种类型:

         通用Interpolation:${expr}

         数字Interpolation:#{expr}或#{expr; format}

l         注意:Interpolation只能用于文本部分

l         通用Interpolation

         插入字符串值:直接输出表达式结果

         插入数字值:根据缺省格式(由#setting指令设置)将表达式结果转换成文本输出;可以使用内建函数string格式化单个Interpolation,下面是一个例子:

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

输出结果是:

$42.00
$42.00
42
$42.00
4,200%

         插入日期值:根据缺省格式(由#setting指令设置)将表达式结果转换成文本输出;可以使用内建函数string格式化单个Interpolation,下面是一个使用格式模式的例子:

${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')'")} 

输出的结果类似下面的格式:

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

         插入布尔值:根据缺省格式(由#setting指令设置)将表达式结果转换成文本输出;可以使用内建函数string格式化单个Interpolation,下面是一个例子:

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

输出结果是:

yes

l         数字Interpolation的#{expr; format}形式可以用来格式化数字,format可以是:

         mX:小数部分最小X位

         MX:小数部分最大X位

         例子:

           <#-- If the language is US English the output is: -->
<#assign x=2.582/>
<#assign y=4/>
#{x; M2}   <#-- 2.58 -->
#{y; M2}   <#-- 4    -->
#{x; m1}   <#-- 2.6 -->
#{y; m1}   <#-- 4.0 -->
#{x; m1M2} <#-- 2.58 -->
#{y; m1M2} <#-- 4.0 --> 
喜欢Java豆技术站点的文章,那就通过 RSS Feed 功能订阅阅读吧!

我要评论

*

* 绝不会泄露



返回首页 | 关于我们 | 联系我们 | 广告合作 | 网站地图 | 友情链接 | 版权声明 | 模板设计