VTL语法参考

简介:
< DOCTYPE html PUBLIC -WCDTD XHTML TransitionalEN httpwwwworgTRxhtmlDTDxhtml-transitionaldtd>

更多请参考:http://velocity.apache.org/engine/devel/user-guide.html

1.变量定义

变量名的有效字符集:

$ [ ! ][ { ][ a..zA..Z ][ a..zA..Z0..9-_ ][ } ]

Examples:

  • 一般方式: $mud-Slinger_9
  • 静态(输出原始字面): $!mud-Slinger_9
  • 正规格式: ${mud-Slinger_9}

2.访问属性

格式规则:

$ [ { ][ a..zA..Z ][ a..zA..Z0..9-_ ]* .[a..zA..Z ][ a..zA-Z0..9-_ ]* [ } ]

Examples:

  • 一般格式: $customer.Address :调用customer对象的getAddress()命令.
  • 正规格式: ${purchase.Total}

3.命令调用

格式规则:

$ [ { ][ a..zA..Z ][ a..zA..Z0..9-_ ]* .a..zA..Z ][ a..zA..Z0..9-_ ]*( [ optional parameter list... ] ) [ } ]

Examples:

  • 一般写码: $customer.getAddress()
  • 正规写法: ${purchase.getTotal()}
  • 传入调用参数: $page.setTitle( "My Home Page" )

VTL的属性调用可以理解为命令调用的简写方式,一般会调用对象的get/set命令.

3.动作指令

1.#set – 建立变量对值的引用

格式规则:

# [ { ] set [ } ] ( $ref = [ "' ]arg[ "' ] )

Examples:

  • 变量引用: #set( $monkey = $bill )
  • 引用原始字符串: #set( $monkey.Friend = 'monica' )
  • 属性引用: #set( $monkey.Blame = $whitehouse.Leak )
  • 命令引用: #set( $monkey.Plan = $spindoctor.weave($web) )

直接引用数字: #set( $monkey.Number = 123 )

  • 列表赋值引用: #set( $monkey.Numbers = [1..3] )
  • 对象数组: #set( $monkey.Say = ["Not", $my, "fault"] )

右值也可以做为一个表达式出现,如下加,减,cheng,除和取模:

  • Addition: #set( $value = $foo + 1 )
  • Subtraction: #set( $value = $bar - 1 )
  • Multiplication: #set( $value = $foo * $bar )
  • Division: #set( $value = $foo / $bar )
  • Remainder: #set( $value = $foo % $bar )

2.#if/#elseif/#else-条件判断

格式规则:

# [ { ] if [ } ] ( [条件表达式] ) [输出内容] [ # [ { ] elseif [ } ] ( [condition] ) [output] ]* [ # [ { ] else [ } ] [output] ] # [ { ] end [ } ]

Usage:

  • condition – 如果是boolean型,根据true或false决定,否则非null时认为是true.
  • output –可以包含VTL的输出内容.

Examples (showing different operators):

Operator Name

Symbol

Alternative Symbol

Example

Equals Number

==

eq

#if( $foo == 42 )

Equals String

==

eq

#if( $foo == "bar" )

Object Equivalence

==

eq

#if( $foo == $bar )

Not Equals

!=

ne

#if( $foo != $bar )

Greater Than

>

gt

#if( $foo > 42 )

Less Than

<

lt

#if( $foo < 42 )

Greater Than or Equal To

>=

ge

#if( $foo >= 42 )

Less Than or Equal To

<=

le

#if( $foo <= 42 )

Boolean NOT

!

not

#if( !$foo )

注意:

1.      “== “操作可以用来比较数字,字符串,或同一个类的不同对象或不同类型的对象. 当是不同类的对象时,会调用它们的toString()命令结果来做比较看是否相等.

2.      也可以如下用法,但注意else处,用{}括起.

#if( $foo == $bar)it's true!#{else}it's not!#end</li>

3.#foreach---使用循环通过列表迭代对象

Format:

# [ { ] foreach [ } ] ( $ref in arg ) statement # [ { ] end [ } ]

Usage:

  • $ref – 引用的要迭代的对象.
  • arg – 可能是:一个列表引用 (i.e. object array, collection, or map), an array list, 或其它列表.
  • statement – 当velocity发现下一个有效对像在列表中,输出可以是一个合法的VTL.

示例 #foreach()用法,:

  • 引用: #foreach ( $item in $items )
  • 数组列表: #foreach ( $item in ["Not", $my, "fault"] )
  • 根据设定的界限: #foreach ( $item in [1..3] )

如下可以取得循环次数的当前值:

<table>

#foreach( $customer in $customerList )

    <tr><td>$velocityCount</td><td>$customer.Name</td></tr>

#end

</table>

默认的循环次数的引用变量名为 $velocityCount. 可以在配置文件velocity.properties中做如下修改成你想要的:

# Default name of the loop counter

# variable reference.

directive.foreach.counter.name = velocityCount

# Default starting value of the loop

# counter variable reference.

directive.foreach.counter.initial.value = 1

注意,可以对所有可循环的次数加一个最大值来控制,默认的是-1,表示元限制:

# The maximum allowed number of loops.

directive.foreach.maxloops = -1

4.#include – 在模板中引入本地文件,不用Velocity解析这个文件

Format:

# [ { ] include [ } ] ( arg[ arg2 ... argn] )

  • arg – 目录TEMPLATE_ROOT下面的有效文件名.

Examples:

  • 直接写文件名: #include( "disclaimer.txt,"opinion.txt" ):如有多个文件时用逗号分开
  • 使用变量引用的文件名: #include( $foo,$bar )

5.#parse – 在模板引用处使用Velocity解析另一个模板输出

Format:

# [ { ] parse [ } ] ( arg )

  • arg -目录TEMPLATE_ROOT下面的有效文件名.

Examples:

  • 直接写文件名: #parse( "lecorbusier.vm" )
  • 使用变量引用的文件名: #parse( $foo )

通过设置配置中的解析层次深度的最大值velocity.properties中项 parse_directive.maxdepth in可以防止死循环. (The default parse depth is 10.)

6.#stop – 中断模板解析

Format:

# [ { ] stop [ } ]

Usage:

在当前模板指令处停止解析,为方便调试用.

7.#macro – 让用户可以定义宏操作(Velocimacro (VM):一组实现特定功能的VTL)

Format:

# [ { ] macro [ } ] ( vmname $arg1 [ $arg2 $arg3 ... $argn ] ) [ VM VTL code... ] # [ { ] #end [ } ]

  • vmname – 宏名字 VM (#vmname)
  • $arg1 $arg2 [ ... ] – 要传给宏的参数VM..
  • [ VM VTL code... ] –宏代码,有效的VTL.

一次定义好了,就可以在其它模板的任何地方使用宏指令来应用.

#vmname( $arg1 $arg2 )

宏(VM)可以写在以下两个地方:

1.      (模板库)Template library: 可以配置用户定义的库以便全站使用

2.      Inline: 放入到一般的模板文件中, 仅当配置参数 velocimacro.permissions.allowInline=true 时生效.

4.Comments 注解

Comments不是运行时所必须的,但你一定要写.

1.单行注解

Example:

## This is a comment.

2.多行注解

Example:

#*
This is a multiline comment.
This is the second line
*#


本文转自 netcorner 博客园博客,原文链接:http://www.cnblogs.com/netcorner/archive/2008/07/11/2912125.html   ,如需转载请自行联系原作者


相关文章
|
24天前
第八章 Helm 模板高效互用动态参数生成
第八章 Helm 模板高效互用动态参数生成
20 1
|
23天前
|
开发工具 Web App开发 IDE
如何对 SAPGUI 里的 ABAP 代码语法检查功能进行自定义增强配套代码
如何对 SAPGUI 里的 ABAP 代码语法检查功能进行自定义增强配套代码
8 2
如何对 SAPGUI 里的 ABAP 代码语法检查功能进行自定义增强配套代码
|
编译器 定位技术 C++
【CMake高级技巧】如何创建一个通用的库查找模板?
【CMake高级技巧】如何创建一个通用的库查找模板?
39 0
|
4月前
|
移动开发 JavaScript 小程序
【uniapp 小程序开发语法篇】资源引入 | 语法介绍 | UTS 语法支持(链接格式)
【uniapp 小程序开发语法篇】资源引入 | 语法介绍 | UTS 语法支持(链接格式)
133 0
|
6月前
|
JavaScript 前端开发
带你读《现代TypeScript高级教程》十二、类型兼容:结构化类型(1)
带你读《现代TypeScript高级教程》十二、类型兼容:结构化类型(1)
|
6月前
|
JavaScript 安全
带你读《现代TypeScript高级教程》十二、类型兼容:结构化类型(2)
带你读《现代TypeScript高级教程》十二、类型兼容:结构化类型(2)
|
7月前
|
编译器 Go 索引
Go 官方标准编译器中所做的优化
Go 官方标准编译器中所做的优化
40 0
|
数据库
通过互联网搜索接口更新拼写语法库的设计
通过互联网搜索接口更新拼写语法库的设计
51 0
|
小程序 JavaScript 前端开发
零基础学小程序 —— 模板语法(二)
零基础学小程序 —— 模板语法(二)
183 0
零基础学小程序 —— 模板语法(二)
Markdown 额外语法支持-有道云笔记
有道云笔记内置Markdown编辑器和使用指南,非技术类笔记用户,千万不要被「标记」、「语言」吓到,Markdown的语法十分简单,常用的标记符号不超过十个,用于日常写作记录绰绰有余,不到半小时就能完全掌握。
266 0
Markdown 额外语法支持-有道云笔记