一、基本语法

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

#if($info.imgs) #else #end

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

jsp实用简明教程Velocity剧本简明教程 Node.js

$i、$msg、$TagUtil.options(...)

3、"{}"用来明确标识Velocity变量;

比如在页面中,页面中有一个$someonename,此时,Velocity将把someonename作为变量名,若我们程序是想在someone这个变量的后面紧接着显示name字符,则上面的标签该当改成${someone}name。

4、"!"用来逼迫把不存在的变量显示为空缺。

如当页面中包含$msg,如果msg工具有值,将显示msg的值,如果不存在msg工具同,则在页面中将显示$msg字符。
这是我们不肯望的,为了把不存在的变量或变量值为null的工具显示为空缺,则只须要在变量名前加一个“!”号即可。
如:

$!msg

二、最佳实践   

1、$!obj  直接返回工具结果。
  

如:在html标签中显示java工具msg的值。

<p>$!msg</p>  

在html标签中显示经由HtmlUtil工具处理过后的msg工具的值  

<p>$!HtmlUtil.doSomething($!msg)</p>

2、#if($!obj) #else #end 判断语句   

如:在EasyJWeb各种开源运用中,我们常常看到的用于弹出提示信息msg的例子。
  

#if($msg)   <script> alert('$!msg'); </script> #end

上面的脚本表示当工具msg工具存在时,输出<script>等后面的内容。

3、#foreach( $info in $list) $info.someList #end  

循环读取凑集list中的工具,并作相应的处理。
  

如:EasyJF开源论坛系统中论(0.3)坛首页显示热门主题的html界面模板脚本:   

#foreach( $info in $hotList1) $!info.title     #end   

上面的脚本表示循环遍历hotList1凑集中的工具,并输出工具的干系内容。

4、#macro(macroName)#end 脚本函数(宏)调用,不推举在界面模板中大量利用。

如:在利用EasyJWeb Tools快速天生的添编削查示例中,可以点击列表的标题栏进行升降排序显示,这是我们在EasyJWeb运用中常常看到的一个排序状态显示的模板内容。
 

函数(宏)定义,一样平常放在最前面   

#macro(orderPic $type)    #if ($orderField.equals($type))       #end    #end 详细的调用如:头衔#orderPic("title")

5、包含文件#inclue("模板文件名")或#parse("模板文件名")   

紧张用于处理具有相同内容的页面,比如每个网站的顶部或尾部内容。
  

利用方法,可以参考EasyJF开源Blog及EasyJF开源论坛中的运用!
  

如:

#parse("/blog/top.html")或#include("/blog/top.html")   

parse与include的差异在于,若包含的文件中有Velocity脚本标签,将会进一步解析,而include将原样显示。

三、关于#set的利用   

在万不得已的时候,不要在页面视图自己声明Velocity脚本变量,也便是只管即便少利用#set。
有时候我们须要在页面中显示序号,而程序工具中又没有包含这个序号属性同,可以自己定义。
如在一个循环体系中,如下所示:   

#set ($i=0)   #foreach($info in $list)   序号:$i   #set($i=$i+1)   #end  

四、Velocity脚本语法择要

1、声明:#set ($var=XXX)   

左边可以是以下的内容   

Variable reference  String literal  Property reference   Method reference   Number literal #set ($i=1)   ArrayList #set ($arr=["yt1","t2"])   算术运算符

2、注释:   

单行 ## XXX   多行 # xxx   xxxx   xxxxxxxxxxxx#

3、变量 Variables   

以 "$" 开头,第一个字符必须为字母。

character followed by a VTL Identifier. (a .. z or A .. Z).   

变量可以包含的字符有以下内容:   

alphabetic (a .. z, A .. Z)   numeric (0 .. 9)   hyphen ("-")   underscore ("_")

4、Properties   

$Identifier.Identifier   $user.name   hashtable user中的的name值.类似:user.get("name")

5、Methods   

object user.getName() = $user.getName()

6、Formal Reference Notation   

用{}把变量名跟字符串分开

如   #set ($user="csy"}    ${user}name    返回csyname $username   $!username   $与$!的差异   当找不到username的时候,$username返回字符串"$username",而$!username返回空字符串""

7、双引号 与 引号   

#set ($var="helo")   test"$var" 返回testhello   test'$var' 返回test'$var'   

可以通过设置 stringliterals.interpolate=false改变默认处理办法

8、条件语句   

#if( $foo )    Velocity!   #end   #if($foo)   #elseif()   #else   #end   当$foo为null或为Boolean工具的false值实行.

9、逻辑运算符:

== && || !

10、循环语句#foreach($var in $arrays ) /

/ 凑集包含下面三种Vector, a Hashtable or an Array #end   #foreach( $product in $allProducts )    <li>$product</li>   #end#foreach( $key in $allProducts.keySet() )    <li>Key: $key -> Value: $allProducts.get($key)</li>   #end#foreach( $customer in $customerList )    <tr><td>$velocityCount</td><td>$customer.Name</td></tr>   #end

11、velocityCount变量在配置文件中定义

Default name of the loop counter variable reference.  directive.foreach.counter.name = velocityCountDefault starting value of the loop counter variable reference.  directive.foreach.counter.initial.value = 1

12、包含文件   

#include( "one.gif","two.txt","three.htm" )

13、Parse导入脚本   

#parse("me.vm" )

14、#stop 停滞实行并返回

15、定义宏Velocimacros ,相称于函数 支持包含功能   

#macro( d )    <tr><td></td></tr>   #end   调用   #d()

16、带参数的宏   

#macro( tablerows $color $somelist )    #foreach( $something in $somelist )    <tr><td bgcolor=$color>$something</td></tr>    #end   #end

17、Range Operator   

#foreach( $foo in [1..5] )