`

(转)freemarker常用语法指南

阅读更多

常用语法
EG.一个对象BOOK
1.输出 $…{book.name}
空值判断:$…{book.name?if_exists },
$…{book.name?default(‘xxx’)}//默认值xxx
$…{ book.name!”xxx”}//默认值xxx
日期格式:$…{book.date?string(’yyyy-MM-dd’)}
数字格式:$…{book?string.number}–20
$…{book?string.currency}–<#-- $20.00 -->
$…{book?string.percent}—<#-- 20% -->
插入布尔值:
<#assign foo=true />
$…{foo?string(”yes”,”no”)} <#-- yes -->

】内置方法

一:数字型
<#assign answer=42/>
$…{answer}
$…{answer?string} <#-- the same as $...{answer} -->
$…{answer?string.number}
$…{answer?string.currency}
$…{answer?string.percent}

<#setting number_format="0.###E0"/>

$…{12345?string(”0.####E0″)}

$…{answer?string(”number”)} 等同于:$…{answer?string.number}.

二:日期型:
预定义格式包括:short ,middle和long。

$…{openingTime?string.short}
$…{openingTime?string.medium}
$…{openingTime?string.long}
组合使用:$…{lastUpdated?string.short_long}
$…{lastUpdated?string(”yyyy-MM-dd HH:mm:ss zzzz”)}

三:逻辑型
foo?string
foo?string(”yes”, “no”)

四:序列的内置方法:
first

last

seq_contains
$…{x?seq_contains(”blue”)?string(”yes”, “no”)}

seq_index_of

seq_last_index_of

reverse

size

sort

sort_by
多层次的hash排序

<#assign members = [
...{"name": ...{"first": "Joe", "last": "Smith"}, "age": 40},
...{"name": ...{"first": "Fred", "last": "Crooger"}, "age": 35},
...{"name": ...{"first": "Amanda", "last": "Fox"}, "age": 25}]>
Sorted by name.last:
<#list members?sort_by(['name', 'last']) as m>
- $…{m.name.last}, $…{m.name.first}: $…{m.age} years old
</#LIST>

chunk:将一个序列分解成几个序列。

<#assign seq = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j']>

<#list seq?chunk(4) as row>
<#list row as cell>$…{cell} </#LIST>
</#LIST>

<#list seq?chunk(4, '-') as row>
<#list row as cell>$…{cell} </#LIST>
</#LIST>
chunk经常用于分栏或者表格输出的格式。

五:hash内置方法:

keys:
values:

】序列 由逗号分隔的变量列表,由方括号限定,类似java中的一维数组

<#assign seq = ["winter", "spring", "summer", "autumn"]>
<#list seq as x>
${x_index + 1}. ${x}

<#if x_has_next>,

</#LIST>

输出
1. winter,
2. spring,
3. summer,
4. autumn

】Hashes(散列)-由逗号分隔的键-值列表,由大括号限定,键和值之间用冒号分隔:{”name”:”green mouse”, “price”:150},键和值都是表达式,但是键必须是字符串。

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

】freemarker的空值和默认值

${user?if_exists}

${user?default(’your name’)}

判断对象是不是null
<#if mouse?exists>
Mouse found
<#else>

或<#if book.name?? >

Mouse found

</#IF>
list 空值判断 <#if bookList?size = 0>

】算术运算

比较操作符-<#if expression_r_r>…</#IF>
1.)使用=(或==,完全相等)测试两个值是否相等,使用!= 测试两个值是否不相等
2.)=和!=两边必须是相同类型的值,否则会产生错误,例如<#if 1 = "1">会引起错误
3.)Freemarker是精确比较,所以”x”、”x “和”X”是不相等的
4.)对数字和日期可以使用<、<=、>和>=,但不能用于字符串
5.)由于Freemarker会将>解释成FTL标记的结束字符,所以对于>和>=可以使用括号来避免这种情况,例如<#if (x > y)>,另一种替代的方法是,使用lt、lte、gt和gte来替代<、<=、>和>=

逻辑操作符-&&(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>

内置函数-用法类似访问hash(散列)的子变量,只是使用”?”替代”.”,例如:user?upper_case
下面列出常用的一些函数:
对于字符串
html-对字符串进行HTML编码
cap_first-使字符串第一个字母大写
lower_case-将字符串转换成小写
trim-去掉字符串前后的空白字符
对于Sequences(序列)
size-获得序列中元素的数目
对于数字
int-取得数字的整数部分(如-1.9?int的结果是-1)

例一:

<#-- test的值为Tom & Jerry -->
$…{test?html}
$…{test?upper_case?html}
结果:
Tom & Jerry
TOM & JERRY

例二:

<#-- seasons的值为"winter", "spring", "summer", "autumn" -->
$…{seasons?size}
$…{seasons[1]?cap_first} <#-- left side can by any expression_r_r -->
$…{”horse”?cap_first}
结果:
4
Spring
Horse

方法的调用
$…{repeat(”What”, 3)}
$…{repeat(repeat(”x”, 2), 3) + repeat(”What”, 4)?upper_case}
结果:
WhatWhatWhat
xxxxxxWHATWHATWHATWHAT

操作符优先顺序
后缀 [subvarName] [subStringRange] . (methodParams)
一元 +expr、-expr、!
内建 ?
乘法 *、 / 、%
加法 +、-
关系 <、>、<=、>=(lt、lte、gt、gte)
相等 =、!=
逻辑 &&
逻辑 ||
数字范围 ..

三.) 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%

例二:

$…{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)

例三:

<#assign foo=true/>
$…{foo?string(”yes”, “no”)}
结果:
yes

例四:

<#-- x is 2.582 and y is 4 -->
#…{x; M2} <#-- 2.58 -->
#…{y; M2} <#-- 4 -->
#…{x; m1} <#-- 2.6 -->
#…{y; m1} <#-- 4.0 -->
#…{x; m1M2} <#-- 2.58 -->
#…{y; m1M2} <#-- 4.0 -->
说明:mX-小数部分最小X位;MX-小数部分最大X位。

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

下面是一个常用的模板例子:

We have these animals:

Name Price
<#list animals as being>

 

<#if being.size = "large"></#IF>
$…{being.name}
<#if being.size="large">
</#IF>

 

$…{being.price} Euros
</#LIST>

<#i nclude "/copyright_footer.html">
注意点:
1.) FreeMarker是区分大小写的;
2.) FTL标记不能位于另一个FTL标记内部,例如:<#if <#i nclude 'foo'>=’bar’>…;
3.) $…{…}只能在文本中使用;
4.) 多余的空白字符会在模板输出时去除;
5.) 如果使用的指令不存在,会产生一个错误消息。

<#-- x的值设定为5 -->
$…{x * x – 100}
$…{x / 2}
$…{12 % 10}
结果:
-75
2.5
2

注意: 操作符两边必须是数字;使用”+”时,如果一边是数字,一边是字符串,就会自动将数字转换为字符串。

使用内建的指令int获得整数部分:

$…{(x/2)?int}
$…{1.1?int}
$…{1.999?int}
$…{-1.1?int}
$…{-1.999?int}
结果:
2
1
1
-1
-1

<!-- -->

分享到:
评论

相关推荐

    FreeMarker开发指南

    本开发指南将深入探讨FreeMarker的关键概念、指令、常用方法以及在Web开发中的注意事项。 1. **基本概念** - **Sequence**: 代表序列,对应Java中的List、数组等非键值对的集合,如ArrayList或数组。可以迭代遍历...

    freemarker_lastest最新最全--文档+安装包+操作手册

    4. **freemarker常用使用文档.ppt**:这个可能是Freemarker的使用教程或者示例集,以PPT形式呈现,适合快速学习和查阅常见用法,例如变量赋值、控制结构、函数调用等。 5. **FreeMarker_2.3.23_Manual_zh_CN.zip**...

    Freemarker使用指南

    Freemarker的常用指令和语法包括: 1. 输出内容:使用`${…}`表示插值,Freemarker会替换花括号内的表达式并输出其真实值。 2. 注释:通过`注释内容 --&gt;`进行注释,这些注释在解析模板时会被忽略。 3. 检测空值:`...

    freemarker&velocity的使用

    FreeMarker和Velocity是两种常用的Java模板引擎,它们在Web开发中用于将静态模板与动态数据结合起来,生成HTML或其他类型的文档。这两个工具都是轻量级的,易于理解和使用,且广泛应用于MVC(Model-View-Controller...

    FreeMarker_2.3.18中文版文档.pdf

    这个2.3.18版本的中文文档为开发者提供了一份详尽的指南,帮助理解并有效地利用FreeMarker进行开发工作。 FreeMarker的核心理念是分离业务逻辑和表现层,即让程序员专注于处理数据,而设计师则可以独立地设计页面...

    FreeMarker_Manual_zh_CN

    - **替换(方括号)语法**:特殊语法的使用场景和方法。 #### 三、程序开发指南 ##### 1. 程序开发入门 - **创建配置实例**:如何初始化FreeMarker环境。 - **创建数据模型**:如何准备并组织数据模型以供模板...

    初学FreeMarker

    **FreeMarker初学者指南** FreeMarker是一个开源模板引擎,它主要应用于Java环境中,用于生成动态内容,如HTML、XML或其他文本格式的文档。这个技术在Web开发中特别常见,因为它可以将业务逻辑与表现层(视图)分离...

    深入浅出FreeMarker(一)-基础教程.pdf

    这些实例将帮助开发者掌握FreeMarker的常用语法和高级特性,进而在实际的项目中综合应用其能力。 最后,文档还将介绍一些常用的FreeMarker资源,如官方文档、社区论坛、第三方教程等,这些资源可以帮助开发者在遇到...

    freemarker使用文档

    4.5 替换(方括号)语法:这是一种特殊的语法,允许在模板中进行条件替换或值的替代。 二部分、程序开发指南 这一部分讲述了如何在Java程序中集成FreeMarker,并使用它来处理数据模型和模板。 一、程序开发入门 ...

    freemarker中文手册

    这个"freemarker中文手册"提供了关于Freemarker的详细介绍和使用指南,对于理解和掌握Freemarker非常有帮助。 一、Freemarker基本概念 1. 模板:Freemarker的核心是模板,它是一个HTML或XML文件,其中包含 ...

    freeMarker开发手册

    FreeMarker允许开发者创建自己的指令,这些自定义指令可以封装常用的逻辑,提高模板的可读性和复用性。 **4.2 命名空间** 为了更好地组织指令和宏,FreeMarker引入了命名空间的概念。通过命名空间,可以避免指令...

    freemarker eclipse 插件

    2. **代码提示**:在编写模板时,提供自动补全功能,帮助开发者快速输入常用的Freemarker指令和变量。 3. **错误检查**:实时检测模板中的语法错误,提高开发效率,减少运行时问题。 4. **模板预览**:允许用户在...

    Freemarker中文教程

    综上所述,FreeMarker是一个功能全面且灵活的模板引擎,通过其丰富的指令和表达式语法,以及强大的数据模型支持,可以高效地生成各种静态文件。无论是对于Web应用还是其他类型的项目,FreeMarker都是一种值得考虑的...

    freemarker 中文手册

    #### 三、FreeMarker设计指南 **快速入门示例** 以一个简单的HTML页面为例,展示如何通过FreeMarker结合数据模型生成最终输出: ```html &lt;title&gt;Welcome! &lt;h1&gt;Welcome ${user}! &lt;p&gt;Our latest product: ${...

    freemarker帮助手册

    2. **模板语法** - **变量**: `${expression}` 用于输出表达式的值,表达式可以是简单的变量名或者复杂的计算。 - **注释**: `&lt;!--#comment--&gt;` 或 `#comment` 用于在模板中添加注释,不会出现在最终输出中。 - *...

Global site tag (gtag.js) - Google Analytics