Apache Velocity 是一个基于java的模板引擎(template engine)。它允许任何人仅仅简单的使用模板语言(template language)来引用由java代码定义的对象。
在 Velocity 中所有的关键字都是以#开头的,而所有的变量则是以$开头。下面为具体语法规则。
## 这是单行注释
#*
Thus begins a multi-line comment. Online visitors won’t
see this text because the Velocity Templating Engine will
ignore it.
*#
#**
This is a VTL comment block and
may be used to store such information
as the document author and versioning
information:
@version 1.1
@author xiao
*#
在Velocity中也有变量的概念,使用 符 声 明 变 量 , 可 以 声 明 变 量 也 可 以 对 变 量 进 行 赋 值 ( 变 量 是 弱 类 型 的 ) 。 另 外 还 可 以 使 用 符声明变量,可以声明变量也可以对变量进行赋值(变量是弱类型的)。另外还可以使用 符声明变量,可以声明变量也可以对变量进行赋值(变量是弱类型的)。另外还可以使用取出在VelocityContext容器中存放的值
#set(${!name} = "velocity") ## string
#set(${!foo} = $bar) ## variable reference
#set($foo =“hello”) ## string
#set($foo.name = $bar.name) ## property reference
#set($foo.name = $bar.getName($arg)) ## method reference
#set($foo = 123) ## number
#set($foo = [“foo”,$bar]) ## ArrayList
注意变量定义语句为#set( $),获取时需要加
模板文件可以使用name或name或{name}定义变量,建议使用后者,name和name和names 的两个变量,如果不选用大括号的话,引擎就没有办法正确识别$names 这个变量。
需要注意,上面代码中 ! 的 写 法 , 使 用 !{}的写法,使用 !的写法,使用vari获取变量时,如果变量不存在,Velocity引擎会将其原样输出,通过使用 ! 的 形 式 可 以 将 不 存 在 的 变 量 变 成 空 白 输 出 . 推 荐 使 用 !{}的形式可以将不存在的变量变成空白输出.推荐使用 !的形式可以将不存在的变量变成空白输出.推荐使用!{}写法
在Velocity中可以使用循环语法遍历集合,语法结构如下:
#foreach($item in $list)
$item
$velocityCount
#end
其中,$item代表遍历的每一项,velocityCount是Velocity提供的用来记录当前循环次数的计数器,默认从1开始计数,可以在velocity.properties文件中修改其初始值
#foreach ($element in $list)
## inner foreach 内循环
#foreach ($element in $list)
This is $element. $velocityCount
inner
#end
## inner foreach 内循环结束
## outer foreach
This is $element.
$velocityCount
outer
#end
语句中也可以嵌套其他的语句,如#if…#else…#end等。
在Velocity中可以使用条件语法对流程进行控制
#if(condition)
...dosonmething...
#elseif(condition)
...dosomething...
#else
...dosomething...
#end
例如
#if($iAmVariable == "goo00d!")
#set($iAmVariable = "goodddd!")
$!iAmVariable
#else
#set($iAmVariable = "goonnnnnn")
$!iAmVariable
#end
在Velocity中也有宏的概念,可以将其作为函数来理解,使用#macro
声明宏
①宏的定义
#macro(宏的名称 $参数1 $参数2 …)
语句体(即函数体)
#end
②宏的调用
#宏的名称($参数1 $参数2 …)
说明:参数之间用空格隔开。
举例
## 声明宏
#macro(sayHello $name)
hello $name
#end
## 使用宏
#sayHello("NICK")
Velocity 也具有逻辑AND, OR 和 NOT 操作符。
## example for AND
#if($foo && $bar)This and that
#end
例子中#if() 指令仅在 f o o 和 foo 和 foo和bar 都为真的时候才为真。如果$foo 为假,则表达式也为假;并且 $bar 将不被求值。如果 f o o 为 真 , V e l o c i t y 模 板 引 擎 将 继 续 检 查 foo 为真,Velocity 模板引擎将继续检查 foo为真,Velocity模板引擎将继续检查bar的值,如果 $bar 为真,则整个表达式为真。并且输出This AND that 。如果 $bar 为假,将没有输出因为整个表达式为假。
停止执行模板引擎并返回,把它应用于debug是很有帮助的。
#include和#parse的作用都是引入本地文件, 为了安全的原因,被引入的本地文件只能在
TEMPLATE_ROOT目录下。
区别:
与#include不同的是,#parse只能指定单个对象。而#include可以有多个
如果您需要引入多个文件,可以用逗号分隔就行:
#include (“one.gif”, “two.txt”, “three.htm” )
在括号内可以是文件名,但是更多的时候是使用变量的:
#include ( “greetings.txt”, $seasonalstock )
#include被引入文件的内容将不会通过模板引擎解析;
而#parse引入的文件内容Velocity将解析其中的velocity语法并移交给模板,意思就是说
相当与把引入的文件copy到文件中。
#parse是可以递归调用的,例如:如果dofoo.vm包含如下行:
Count down.
#set ($count = 8)
#parse (“parsefoo.vm”)
All done with dofoo.vm!
那么在parsefoo.vm模板中,你可以包含如下VTL:
$count
#set($count = $count - 1)
#if ( $count > 0 )
#parse( “parsefoo.vm” )
#else
All done with parsefoo.vm!
#end的显示结果为:
Count down.
8
7
6
5
4
3
2
1
0
All done with parsefoo.vm!
All done with dofoo.vm!
注意:在vm中使用#parse来嵌套另外一个vm时的变量共享问题。如:
->a.vm 里嵌套 b.vm;
->a.vm 里定义了变量 $param;
->b.vm 里可以直接使用$param,无任何限制。
但需要特别注意的是,如果b.vm里同时定义有变量$param,则b.vm里将使用b.vm里定义的值。
如果reference被定义,两个’\’意味着输出一个’\’,如果未被定义,刚按原样输出。
如:
#set($email = “foo” )
$emai
l\$email
输出:
foo
\foo
如果$email 未定义
输出:
Velocity内置了一些对象,在vm模版里可以直接调用,列举如下:
r e q u e s t 、 request、 request、response、$session,另外,模板内还可以使用 $msg内的消息工
具访问 Struts 的国际化资源,达到简便实现国际化的方法。
对数组的访问在Velocity中存在问题,因为Velocity只能访问对象的方法,而数组
又是一个特殊的Array,所以虽然数组可以进行循环列举,但却不能定位访问特定
位置的元素,如 strs[2],数组对固定位置元素的访问调用了Array的反射方法
get(Object array, int index),而Velocity没能提供这样的访问,所以数组要么改成
List等其他类容器的方式来包装,要么就通过公用Util类的方式来提供,传入数组
对象和要访问的位置参数,从而达到返回所需值的目的。