现在的位置: 首页 > 综合 > 正文

velocity的使用-语法

2017年12月26日 ⁄ 综合 ⁄ 共 1485字 ⁄ 字号 评论关闭

1、if-else判断

(1)判断空值:$null.isNull($devices)

(2)格式:

#if ($velocityCount == 1)
    print
 #else
    print2
#end

2、for-each

(1)格式:

#foreach($device in $devices)
     #if ($velocityCount == 1)
        print$device
    #else
        print2$device
   #end
 #end

3、set

#set($foo="bar")或者#set($foo.bar=$test)

4、parse、include

#parse("file.vm")

5、内置变量

(1)$null-用于判断空

$null.isNotNull($locationtime)

$null.isNull($locationtime)

(2)$velocityCount-循环时表示数组下标

6、遇到的问题

(1)与jquery兼容的问题:

对于jquery的插件js文件,可以考虑放到一个共同的vm文件中,使用include文件导入。

如果要在vm文件中使用$,可以用jQuery替代

(2)$contactdetail.name.lastName

直接在页面中使用该表达式时,如果lastName不存在,就会显示“$contactdetail.name.lastName”,

解决办法是使用:$!{contactdetail.name.lastName}

7、使用ResourceTool读取资源文件

在tools.xml中的toolbox节点添加

<tool key="config" class="org.apache.velocity.tools.generic.ResourceTool" bundles="config" locale="zh_CN"/>

bundles表示文件的前缀名,key的值后续在vm文件中用来做为变量名引用。

在vm文件中这样应用

$(config.某个key)

8、使用log4j打印velocity日志

在velocity.properites文件中添加

runtime.log.error.stacktrace = false  
runtime.log.warn.stacktrace = false  
runtime.log.info.stacktrace = false  
runtime.log.logsystem.class = org.apache.velocity.runtime.log.SimpleLog4JLogSystem  
runtime.log.logsystem.log4j.category = velocity_log 

log4j.properties文件中配置

log4j.logger.velocity_log=INFO,velocity

log4j.logger.velocity_log=ERROR,velocity
log4j.appender.velocity=org.apache.log4j.DailyRollingFileAppender
log4j.appender.velocity.layout=org.apache.log4j.PatternLayout
log4j.appender.velocity.layout.ConversionPattern=[%d{yyyy-MM-dd HH:mm:ss,SSS}] [%p] [%C.%M:%L] %m%n
log4j.appender.velocity.File=/var/log/velocity.log

抱歉!评论已关闭.