Velocity是一个基于java的模板引擎(template engine)。它允许任何人仅仅简单的使用模板语言(template language)来引用由java代码定义的对象。
当Velocity应用于web开发时,界面设计人员可以和java程序开发人员同步开发一个遵循MVC架构的web站点,也就是说,页面设计人员可以只 关注页面的显示效果,而由java程序开发人员关注业务逻辑编码。Velocity将java代码从web页面中分离出来,这样为web站点的长期维护提 供了便利,同时也为我们在JSP和PHP之外又提供了一种可选的方案。
1、"#"用来标识Velocity的脚本语句,包括#set、#if 、#else、#end、#foreach、#end、#iinclude、#parse、#macro等;
如:
#if($info.imgs)
#else
#end
2、"$"用来标识一个对象(或理解为变量);
如: i 、 i、 i、msg、$TagUtil.options(…)等。
3、"{}"用来明确标识Velocity变量;
比如在页面中,页面中有一个$someonename,此时,Velocity将把someonename作为变量名,若我们程序是想在someone这 个变量的后面紧接着显示name字符,则上面的标签应该改成${someone}name。
4、"!"用来强制把不存在的变量显示为空白。
如当页面中包含 m s g , 如 果 m s g 对 象 有 值 , 将 显 示 m s g 的 值 , 如 果 不 存 在 m s g 对 象 同 , 则 在 页 面 中 将 显 示 msg,如果msg对象有值,将显示msg的值,如果不存在msg对象同,则在页面中将显示 msg,如果msg对象有值,将显示msg的值,如果不存在msg对象同,则在页面中将显示msg字符。这是我们不希望的,为了把不存 在的变量或变量值为null的对象显示为空白,则只需要在变量名前加一个“!”号即可。
如:$!msg
#set($name = “hello”) 说明:velocity中变量是弱类型的。
当使用#set 指令时,括在双引号中的字面字符串将解析和重新解释,如下所示:
#set($directoryRoot = “www” )
#set($templateName = “index.vm” )
#set( t e m p l a t e = " template = " template="directoryRoot/$templateName" )
$template
输出将会是:www/index.vm
注:在velocity中使用$2.5这样的货币标识是没有问题得的,因为velocity中的变量总是以一个大写或者小写的字母开始的。
n a m e , 也 可 以 写 成 : {name} ,也可以写成: name,也可以写成:name。提倡用前面的写法。
例如:你希望通过一个变量$vice来动态的组织一个字符串。
Jack is a $vicemaniac.
本来变量是 v i c e 现 在 却 变 成 了 vice现在却变成了 vice现在却变成了vicemaniac,这样Veloctiy就不知道您到底要什么了。所以,
应该使用规范的格式书写 : Jack is a ${vice}maniac
现在Velocity知道变量是 v i c e 而 不 是 vice而不是 vice而不是vicemaniac。
注意:当引用属性的时候不能加{}
$name=“hello”
赋值的左边必须是一个变量或者是属性引用。右边可以是下面六种类型之一:
变量引用,字面字符串,属性引用,方法引用,字面数字,数组列表。
注意:
①如果上述例子中的右值是null, 则左值不会被赋值,也就是说会保留以前的值。
②velocity模板中未被定义的变量将被认为是一个字符串。例如:
③velocity模板中不会将reference解释为对象的实例变量。例如:$foo.Name将被解释为Foo对象的getName()方法,而不是Foo对象的Name实例变量。
#foreach ($element in $list)
This is $element
$velocityCount
#end
#if (condition)
#elseif (condition)
#else
#end
#foreach ($element in $list)
## inner foreach 内循环
#foreach ($element in $list)
This is $element. $velocityCount
inner
#end
## This is a single line comment.
#*
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 wzy
*#
Velocity 也具有逻辑AND, OR 和 NOT 操作符。
## example for AND
#if($foo && $bar)This and that
#end
Velocity中的宏我们可以理解为函数。
#macro(宏的名称 $参数1 $参数2 …)
语句体(即函数体)
#end
#宏的名称($参数1 $参数2 …)
说明:参数之间用空格隔开。
停止执行模板引擎并返回,把它应用于debug是很有帮助的。
#include和#parse的作用都是引入本地文件, 为了安全的原因,被引入的本地文件只能在TEMPLATE_ROOT目录下。
区别:
(1) 与#include不同的是,#parse只能指定单个对象。而#include可以有多个
##如果您需要引入多个文件,可以用逗号分隔就行:
#include ("one.gif", "two.txt", "three.htm" )
##在括号内可以是文件名,但是更多的时候是使用变量的:
#include ( “greetings.txt”, $seasonalstock )
(2) #include被引入文件的内容将不会通过模板引擎解析;
而#parse引入的文件内容Velocity将解析其中的velocity语法并移交给模板,意思就是说相当与把引入的文件copy到文件中。另外,#parse是可以递归调用的。
如果reference被定义,两个’\’意味着输出一个’\’,如果未被定义,刚按原样输出。
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类的方式来提供,传入数组对象和要访问的位置参数,从而达到返回所需值的目的。
velocity语法教程
velocity教程