<# ... > 中存放所有freemaker的内容,之外的内容全部原样输出。
|
Escape sequence | Meaning |
---|---|
/" | Quotation mark (u0022) |
/' | Apostrophe (a.k.a. apostrophe-quote) (u0027) |
// | Back slash (u005C) |
/n | Line feed (u000A) |
/r | Carriage return (u000D) |
/t | Horizontal tabulation (a.k.a. tab) (u0009) |
/b | Backspace (u0008) |
/f | Form feed (u000C) |
/l | Less-than sign: < |
/g | Greater-than sign: > |
/a | Ampersand: & |
/{ | Curly bracket: { |
/xCode | Character given with its hexadecimal Unicode code (UCS code) |
如果想打印${,则需要将{转义,可以写成"$/{user}",或者可以用生字符(r指令):$(r "${xx}"}
序列构成:<#list ["winter", "spring", "summer", "autumn"] as x>${x}</#list>
不同的对象可以存放在一个序列里面,比如: [2 + 2, [1, 2, 3, 4], "whatnot"]. 第一个是数字,第二个是序列,第三个是字符串。
可用采用start..end的方式来定义一个数字序列,start可以小于end,同时,end也可以省略。
hash取值支持一下四种模式: book.author.name, book["author"].name, book.author.["name"], book["author"]["name"].
特殊变量是指freemaker引擎本身定义的变量。访问时,以.variable_name的语法访问。
变量表达式支持嵌套模式,比如:${"Hello ${user}!"}。
变量表达式在指令中的使用情况:
变量表达式可以在指令中,用“”的方式存在,不如:<#include "/footer/${company}.html">.
但是不允许下面的方式存在: <#if ${isBig}>Wow!</#if>, 正确写法是:<#if isBig>Wow!</#if>.
而且 <#if "${isBig}">Wow!</#if>写法也不正确,因为"${isBig}"返回的是字符串,不是boolean类型。
字符串中取字符或字符串采用以下语法:${user[0]},${user[0..2]} ${user[4..]},${user?string(4)}
序列操作:
加法:<#list ["Joe", "Fred"] + ["Julia", "Kate"] as user> 但要注意串联之后的读取速度变慢。
子序列:seq[1..4]
序列和hash的串联都只能用于两个相加,不能有多个相加的模式,hash相加,如果两个相加的hash存在相同的key,则后面会覆盖前面的。
在使用>=或者>时,需要注意一些问题,因为freemaker会将>解释成标记的关闭符,为了解决这个问题,需要在表达式加上括号,比如: <#if (x > y)>. 或者使用 > and <符号来代替。
无值变量(包括无该变量,null,返回void,无属性等):unsafe_expr!default_expr or unsafe_expr! or (unsafe_expr)!default_expr or (unsafe_expr)!
缺省值可以是任何类型,不一定是数字,比如:hits!0 或者 colors!["red", "green", "blue"].
如果缺省值忽略,那么将会默认为空串、空序列或者空hash,因为freemarker支持多类型的值。不过要让默认值为0或false,则不能省略缺省值。
非顶层变量的无值处理:
product.color!"red":只处理product不为空,color为空的缺省值处理,如果product为空,则freemaker会抛 出异常。(product.color)!"red":则会处理product为空,color为空,或者没有color属性的无值情况。
无值变量的判断操作:unsafe_expr?? or (unsafe_expr)??