velocity教程

Velocity是什么

​ Velocity是一个基于java的模板引擎(template engine)。它允许任何人仅仅简单的使用模板语言(template language)来引用由java代码定义的对象。

​ 当Velocity应用于web开发时,界面设计人员可以和java程序开发人员同步开发一个遵循MVC架构的web站点,也就是说,页面设计人员可以只 关注页面的显示效果,而由java程序开发人员关注业务逻辑编码。Velocity将java代码从web页面中分离出来,这样为web站点的长期维护提 供了便利,同时也为我们在JSP和PHP之外又提供了一种可选的方案。

Velocity的符号

1、"#"用来标识Velocity的脚本语句,包括#set、#if 、#else、#end、#foreach、#end、#iinclude、#parse、#macro等;

如:

#if($info.imgs)

#else

#end

2、"$"用来标识一个对象(或理解为变量);

如: i 、 i、 imsg、$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对象同,则在页面中将显示 msgmsgmsgmsgmsg字符。这是我们不希望的,为了把不存 在的变量或变量值为null的对象显示为空白,则只需要在变量名前加一个“!”号即可。
如:$!msg

Velocity的语法

1. 变量

(1)变量的定义:

#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中的变量总是以一个大写或者小写的字母开始的。

(2)变量规范的写法

n a m e , 也 可 以 写 成 : {name} ,也可以写成: namename。提倡用前面的写法。

例如:你希望通过一个变量$vice来动态的组织一个字符串。

Jack is a $vicemaniac.

本来变量是 v i c e 现 在 却 变 成 了 vice现在却变成了 vicevicemaniac,这样Veloctiy就不知道您到底要什么了。所以,

应该使用规范的格式书写 : Jack is a ${vice}maniac

现在Velocity知道变量是 v i c e 而 不 是 vice而不是 vicevicemaniac。

注意:当引用属性的时候不能加{}

(3)变量的赋值:

$name=“hello”

赋值的左边必须是一个变量或者是属性引用。右边可以是下面六种类型之一:

变量引用,字面字符串,属性引用,方法引用,字面数字,数组列表。

注意:

  • ①如果上述例子中的右值是null, 则左值不会被赋值,也就是说会保留以前的值。

  • ②velocity模板中未被定义的变量将被认为是一个字符串。例如:

  • ③velocity模板中不会将reference解释为对象的实例变量。例如:$foo.Name将被解释为Foo对象的getName()方法,而不是Foo对象的Name实例变量。

2. 循环

#foreach ($element in $list)
This is $element
   $velocityCount
#end

3. 条件语句

#if (condition)
#elseif (condition)
#else
#end

4. 语句的嵌套

#foreach ($element in $list)
## inner foreach 内循环
#foreach ($element in $list)
This is $element. $velocityCount 
inner
#end

5. 注释

(1)单行注释:

 ## This is a single line comment.

(2)多行注释:

#*
 Thus begins a multi-line comment. Online visitors won’t
 see this text because the Velocity Templating Engine will
 ignore it.
 *#

(3)文档格式:

#**

 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

*#

6. 关系和逻辑操作符

Velocity 也具有逻辑AND, OR 和 NOT 操作符。

## example for AND
#if($foo && $bar)This and that
#end

7.Velocity 中的宏

Velocity中的宏我们可以理解为函数。

①宏的定义

#macro(宏的名称 $参数1 $参数2 …)
       语句体(即函数体)
#end

②宏的调用

​ #宏的名称($参数1 $参数2 …)

说明:参数之间用空格隔开。

8.#stop

停止执行模板引擎并返回,把它应用于debug是很有帮助的。

9.#include与#parse

#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是可以递归调用的。

10.转义字符\的使用

如果reference被定义,两个’\’意味着输出一个’\’,如果未被定义,刚按原样输出。

11.内置对象

Velocity内置了一些对象,在vm模版里可以直接调用,列举如下:

r e q u e s t 、 request、 requestresponse、$session,另外,模板内还可以使用 $msg内的消息工具访问 Struts 的国际化资源,达到简便实现国际化的方法。

12. 数组访问

对数组的访问在Velocity中存在问题,因为Velocity只能访问对象的方法,而数组又是一个特殊的Array,所以虽然数组可以进行循环列举,但却不能定位访问特定位置的元素,如 strs[2],数组对固定位置元素的访问调用了Array的反射方法get(Object array, int index),而Velocity没能提供这样的访问,所以数组要么改成List等其他类容器的方式来包装,要么就通过公用Util类的方式来提供,传入数组对象和要访问的位置参数,从而达到返回所需值的目的。

参考

velocity语法教程

velocity教程

你可能感兴趣的:(velocity教程)