`
Josh_Persistence
  • 浏览: 1653663 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类

轻松学习Velocity - Velocity基本用法和常用的用法

阅读更多

前言:

        1. 不少人看过或了解过Velocity,Velocity字面翻译为:速度、速率、迅速。在Web开发里,用过的人可能不多,大都基本知道和在使用Struts,到底Velocity和Struts是如何联系,怎么看待Velocity呢?让我们来尝试一下,了解Velocity的概念,通过在这里的介绍,强调在技术选择上的问题,让大家在选择项目开发时,可以考虑Velocity,另外也让大家了解它的思想,毕竟它提供了一个很好的思维方式,给大家换换筋骨,换一种思考的方式。 

2. 本文基于你对Java开发有一定基础,知道MVC,Struts等开发模式。 

 

一、什么叫Velocity? Velocity是一种Java模版引擎技术,该项目由Apache提出,由另外一种引擎技术Webmacro引深而来。那什么是官方的Velocity定义呢?  Apache对它的定义是:一种基于Java的模板引擎,允许任何人使用简单而强大的模板语言来引用定义在Java代码中的对象。可以在http://jakarta.apache.org/velocity/index.html查找更多信息。

       

        其实说白了Velocity也就是MVC架构的一种实现,但它更多的是关注在Model和View之间,作为它们的桥梁。对于MVC的最流行架构Struts来说,相信大家都不陌生,很多开发人员已经大量在使用Struts架构,包括IBM的Websphere 5以上的管理平台版本,Struts技术很好的实践了MVC,它有效的减少Java代码在View(Jsp)中的出现,但在Model和View之间还是依靠Struts的Taglib技术来实现,试想如果前台开发的网页设计师对Struts乃至Taglib不熟(相信也挺难熟的,包括后期的维护人员也一样),将会对网页设计师和前台开发工程师的相互协作开发带来很大的难度,现实开发中也还是存在这样事实,网页设计师和前台开发之间的工作或多或少还是存在一定的耦合,怎样最大限度的解决这个难题呢?还是让我们来看看Velocity或者说这个概念吧。

 

二、具体实例:

先做一个最简单的Velocity开发例子,让大家看看Velocity是怎样工作的: 

 

1、创建1个文件,文件名为:hello-velocity.vm,即velocity模版(其实和html一样),内容: 

 

<html> 

 

<title>Hello Velocity</title> 

 

       <body> 

 

         Welcome $name to Josh_Persistence.blog! 

 

         today is $date. 

 

       </body> 

 

</html> 

   

2、创建1个java文件,HelloVelocity.java,内容:   

package com.wsheng.velocity; 

 

import java.io.StringWriter; 

import java.util.*; 

import org.apache.velocity.app.VelocityEngine; 

import org.apache.velocity.Template; 

import org.apache.velocity.VelocityContext; 

 

public class HelloVelocity { 

 

public static void main(String[] args) throws Exception { 

 

       // 初始化并取得Velocity引擎 

       VelocityEngine ve = new VelocityEngine(); 

       ve.init(); 

 

      // 取得velocity的模版 

      Template t = ve.getTemplate("hello-velocity.vm"); 

 

      // 取得velocity的上下文context 

      VelocityContext context = new VelocityContext(); 

 

     // 把数据填入上下文 

     context.put("name", "sheng"); 

     context.put("date", (new Date()).toString()); 

 

     // 为演示后面的例子,提前输入List数值 

     List temp = new ArrayList(); 

     temp.add("1"); 

     temp.add("2"); 

 

    context.put("list", temp); 

 

    // 输出流 

   StringWriter writer = new StringWriter(); 

 

   // 转换输出 

   t.merge(context, writer); 

 

  System.out.println(writer.toString()); 

 

 

 

3、下载运行需要依赖的包:在http://jakarta.apache.org/site/binindex.cgi上下载最新的VelocityXXX.zip,

在下载后的velocityXXX.zip中的lib中解压出velocityXX.jar,commons-collections.jar、logkit-XXX.jar

 

4、 运行后的输出结果:

 

<html> 

 

      <title>Hello Velocity</title> 

 

<body> 

 

     Welcome Sheng to Josh_Persistence.blog! 

 

     today is Tue June 18 19:26:37 CST 2013. 

 

</body> 

 

</html> 

 

         以上是最简单的运行结果,怎么样,知道个大概吧,模版hello-velocity.vm里的2个定义变量$name和$date分别被context.put("name", "sheng")和context.put("date", (new Date()).toString())所设的值替代了。 

         由此看来业务流程处理包括业务结果基本在model这层全部解决,而view这一层基本只用使用简单的VTL(Velocity Template Language)来展示。这样,Jsp岂不是不用了么?是的,这样的使用模式有点象早前的CGI方式:)由Velocity自动输出代码,并且Velocity在这方面的能力也很强,Turbine里就采用了Velocity来产生很多代码。 

在Velocity中,变量的定义都是使用“$”开头的,$作为Velocity的标识符。字母、数字、中划和下划线都可以作为Velocity的定义变量。

      此外我们还需要注意的是Velocity特色的变量定义,如:$student.No、$student.Address,

它有2层含义:

      第1种是如果student是hashtable,则将从hashtable中提取key为No和Address的值,

      第2种就是它有可能是调用方法,即上面2个变量将被转换为student.getNo()和student.getAddress()。

Velocity可以处理servlet中的java code返回的值可以是对象,还可以调用对象的方法,如$student.getAddress()等等,在此就不一一举例和深入了。 

     上面的例子只是简单的举例,现在当然不少人已经不满足这样的例子了,实际的应用中我们还常常需要作些选择性展示和列举一些迭代数据,如List列表,当然Velocity(具体来说应该是VTL模版语言)也支持这项功能,此外还支持其他一些常用的展示,如模版内部的变量如Jsp内的变量),还有强大一些的如创建宏以实现自动化,让我们继续接着往下看吧。 

 

1. Velocity中使用#set定义变量

我们还是使用上面的例子,把模版hello-velocity.vm中的内容改为: 

 

#set( $iAmVariable = "good!" ) 

Welcome $name to Josh_Persistence.blog! 

 

today is $date. 

 

$iAmVariable 

 

重新执行上面的运行命令,结果: 

 

Welcome Sheng to Josh_Persistence.blog! 

 

today is Tue June 18 19:26:37 CST 2013. 

 

good! 

 

    可以看出模版中的变量定义为#set开头的语句,不是很难理解,执行后模版中的变量$iAmVariable都转换成定义的值:good! 

 

2. If, else, end的使用。

再来看看简单的选择,把模版hello-velocity.vm中的内容改为: 

#set ($admin = "admin") 

#set ($user = "user") 

 

#if ($admin == $user) 

Welcome admin! 

#else 

Welcome user! 

#end 

 

执行运行命令,结果: 

 

Welcome user! 

 

可以看到判断语句只是简单的#if ()、#else、#end,不是很复杂。

 

3. List的迭代,把模版hello-velocity.vm中的内容改为: 

#foreach($product in $list ) 

<li>$product</li> 

#end 

 

执行运行命令,结果: 

<li>1</li> 

<li>2</li> 

 

把在例子中预先保存在VelocityContext的List中的值列举了出来,是不是很方便啊?仅仅只是用了#foreach($variable in xx而已。

 

4. hashtable的迭代:

如果上面的List换成Hashtable,则可以用下面的语法: 

 

#foreach($key in $hashVariable.keySet() ) 

 

<li> $key ‘s value: $ hashVariable.get($key) </li> 

 

 

#end 

 

5.velocity处理java bean,我们增加一个bean: 

 

package com.wsheng.velocity; 

 

public class Student { 

 

// 注意class的属性是public的 

public String no = ""; 

public String address = ""; 

 

public Student(String _no, String _address) { 

no = _no; 

address = _address; 

 

public String getAddress() { 

return address; 

 

public void setAddress(String address) { 

this.address = address; 

 

public String getNo() { 

return no; 

 

public void setNo(String no) { 

this.no = no; 

这个Student是十足的javabean,或者说是data bean,常见的用来装载数据的类,然后我们修改HelloVelocity.java,把: 

 

temp.add("1"); 

 

temp.add("2"); 

 

替换成: 

 

temp.add(new Student("123", "Guangzhou")); 

 

temp.add(new Student("456", "Zhuhai")); 

 

再把hello-velocity.vm的内容改为: 

 

#foreach ($s in $students) 

 

<$velocityCount> Address: $s.address 

 

#end 

 

重新编译和执行运行命令,结果如下: 

 

<1> Address: Guangzhou 

 

<2> Address: Zhuhai 

 

这样把list中Student的数据打印了出来,大功告成!这里用了Velocity的内建变量$velocityCount,指的是默认的列举序号,从1开始,也可以改成0开始,但需要在Velocity.properties中更改,Velocity.properties位于velocity-XX.jar包内的目录org\\apache\\velocity\\runtime\\defaults 下。 

 

6. Velocity处理嵌套的迭代的处理,我们看看下面的模版例子就清楚了: 

 

#foreach ($element in $list) 

 

-- inner foreach -- 

 

#foreach ($element in $list) 

 

This is $element. 

 

$velocityCount 

 

#end 

-- inner foreach -- 

 

-- outer foreach -- 

 

This is $element. 

 

$velocityCount 

 

-- outer foreach -- 

 

#end 

 

       看出来了吧,Velocity是支持标签嵌套的,这个可是很强大的功能,这里就不深入演示了,如果有兴趣,自己试试吧。 

 

其实,稍为深入思考刚刚我们举的例子,就已经可以看出来,Velocity的用处在哪里?即Servlet + Velocity的模式,另外,还记得我们早期Jsp开发的模式Jsp+JavaBean吗?在这里,我们更改为Servlet+JavaBean+Velocity,想想,是不是已经替代了Jsp+JavaBean,并更彻底的把Java代码去除在Jsp(vm)外,如果光使用Struts(Servlet+Jsp),那么带来的代价是Java代码总或多或少出现在Jsp上,即使可以做到不出现Java代码,但做过复杂架构系统的开发者都知道,代价也是很昂贵的,并且在可维护性、和网页设计师的集成开发上存在一定的困难,所以我们在这里能感觉到,Servlet+JavaBean+Velocity的模式较好的实现了OOD的概念。而在效率上,大家也不用担心,此种结合方式比Servlet+Jsp的方式要高效一些。 

愿意了解Velocity的人应该不少,但真正实用到项目的,也许不多(还是有些项目在使用,如Jute),毕竟和Jsp比起来,Jsp更标准、更广泛使用和有不少开发工具已经支持Jsp开发。但Velocity的功能不会仅仅局限在和Jsp竞争的局面,由上可看出它在自动代码输出方面功能很强,前面提到Turbine就是采用Velocity来生成很多代码,你也可以稍加改动就可以做成代码生成器,或其他模版生成上,都是很不错的想法。 

 

7. Velocity与国际化 

 

Velocity本身支持模版的国际化编码转换,看看Velocity提供的方法: 

 

Public Template getTemplate (Stirng template, String encoding), 

 

由此推测这样做其实不能彻底的做到国际化。 

 

最简单的在Struts中国际化的概念,即在Jsp上使用国际化语言标签的方式来做到,而每种语言采用不同的语言标签库的方式,

引申到这里,其实手工来做一样可以做到,只不过需要稍加手工处理而已。 

 

好在已经有人处理了上面所说问题,做成了Velocity的tools: MessageTool,提供了变量text包含国际化标签,

这样只需要简单的编写标签代码即可,如:$text.get(‘title’),

更多具体的内容还可在http://jakarta.apache.org/velocity/tools/struts/MessageTool.html 中了解。 

 

8. Velocity返回null的情况:

jobLocation="#if($!candidate.job.location.title)$!StringEscapeUtils.escapeXml($!candidate.job.location.title)#end"

如果只是$!candidate.job,则不会有任何信息返回。candidate.job.location也不会有信息返回。即使它们都不为空,不返回的原因是他们都是类对象,而不是具体的属性。

 

      好了,基于Velocity的介绍就说这么多,再说说其他引伸方面的内容吧。有人评论Velocity不是标准的MVC结构,没错,刚开始就说过Velocity只是Model和View之间的良好结合,只是个好的模版引擎,毕竟还没有形成MVC三者良好的结合。好在Apache又基于Struts和Velocity的结合,推出了VelocityStruts,这里简单介绍它的概念,它是在Struts的结构上,在业务逻辑处理的Action后,把业务流程转向基于Velocity的显示层,从而代替Jsp作为View层。以上我们也看到了所举的例子基本上只是基于原理和演示,没有和Web开发紧密结合起来,这方面内容也许我以后会在另一篇博客中讲述VelocityStruts的内容时再来结合吧。 谈到Velocity,在这里要顺便提提FreeMarker,FreeMarker也是一种模版引擎,和Velocity功能基本类似,都是简单和轻量级的工具,但功能上较Velocity有不少增强的地方,我也会另外写一篇的博客来深入了解吧。

4
5
分享到:
评论
2 楼 Josh_Persistence 2013-06-23  
wuchsh2013 写道
不错,是个好的模板工具

是的,很不错的,比如用于发Email时的Email模板。
1 楼 wuchsh2013 2013-06-23  
不错,是个好的模板工具

相关推荐

    Velocity java开发指南

    - **基本使用模式**:Velocity 的核心思想是将数据对象与模板文件结合,通过 Velocity 引擎解析模板中的指令和表达式,最终生成所需的文本输出。 - **单实例 vs 多实例**:选择使用单实例模式还是多实例模式取决于...

    JAVAEE Velocity例子工程

    这个工程旨在通过实际的代码演示,帮助开发者理解并掌握Velocity的基本用法,无需深入学习复杂的配置文件。 在传统的Java Web开发中,视图层通常与业务逻辑和数据层分离,Velocity就扮演了视图的角色,允许开发者将...

    Velocity快速指南

    下面通过一个简单的例子来介绍Velocity的基本用法: ```html #set($foo="baidu") 你好啊$foo! ``` 这段代码将输出:“你好啊百度!”其中`#set($foo="baidu")`用于定义一个名为`$foo`的变量,并将其值设置为...

    velocity1.5

    - **性能提升**:Velocity 1.5对解析速度和内存使用进行了优化,使得在处理大量模板时效率更高。 **3. 使用Velocity 1.5** - **集成到Java Web项目**:Velocity可以轻松地与Servlet容器如Tomcat、Jetty等集成,...

    leaflet-velocity 风场流线效果 原生js版本 .zip

    首先,让我们了解`leaflet-velocity.js`的基本用法。这个插件是基于OpenLayers的Velocity模块改编的,适用于Leaflet环境。它能够解析来自海洋学和气象学数据源(如GFS或HRRR)的NetCDF或GRIB文件,将风速和风向数据...

    Velocity语法笔记

    #### 一、Velocity 概述与基本用法 Velocity 是一个基于 Java 的模板引擎,主要用于 Web 应用程序中生成动态页面。它提供了丰富的语法支持,使得开发者可以更轻松地处理数据并将其转换为最终的 HTML 页面或其他格式...

    Velocity用户手册(中文版)

    这份中文版的Velocity用户手册将深入解析其语法和用法。 ** Velocity语法基础 ** 1. **变量引用**:在Velocity中,变量以$符号开头,例如 `$name`,表示要引用的变量。 2. **括号内引用**:如果变量名包含特殊...

    velocity学习资料

    - **VTL语法**:熟悉 #set、#if、#foreach、#else、#break、#continue 等基本指令的用法,以及如何定义和引用变量。 - **Context 使用**:了解如何创建和操作 Context,将 Java 对象绑定到模板,以及如何从模板中...

    velocity手册

    Velocity的基本用法 - **Velocity Template Language (VTL)**:这是Velocity提供的强大脚本语言,它允许Web页面设计者轻松地将动态内容嵌入到静态模板中。VTL支持一系列内置函数和语法结构,让非专业程序员也能...

    velocity快速入门

    ### Velocity快速入门详解 ...通过学习 Velocity 的基本语法和使用方法,您可以轻松地创建出动态的、个性化的 Web 页面。此外,Velocity 的灵活性还使其成为代码生成和文档自动化等任务的理想选择。

    精通Apache Velocity

    ### 精通Apache Velocity #### 一、Apache Velocity简介 Apache Velocity 是一款基于 Java 的...通过学习本教程,你可以掌握 Velocity 的基本用法以及如何将其应用于实际项目中,进一步提升 Web 开发效率和用户体验。

    velocity文档

    它涵盖了Velocity的基本用法,如变量和指令的使用,以及如何与Java对象进行交互。此外,还可能包含高级主题,如自定义工具库、模板调试和性能优化,帮助开发者充分利用Velocity的强大功能。 ** NetJava.cn--...

    velocityWebEdit

    它提供了对 Velocity 模板语言(Velocity Template Language,VTL)的高亮显示、智能编辑以及语法检查等功能,使得在 Eclipse 中编写和调试基于 Velocity 的网页模板变得更为轻松。 ** Velocity 介绍 ** Velocity ...

    velocityjs-dash-docset:这是一个用于破折号的 Velocity.js 文档集,旨在加快 AlfredDash 工作流程

    这个“velocityjs-dash-docset”是针对 Velocity.js 1.1.0 版本的,包含所有相关的 API 参考、教程和示例,使得开发人员能够更便捷地在 AlfredDash 中查找和学习 Velocity.js 的功能和用法。通过下载 ZIP 文件或克隆...

    NVelocity用法

    ### NVelocity用法详解 ...通过掌握其基本概念和关键功能,你可以轻松地生成动态内容,从而提高应用程序的灵活性和效率。无论是处理复杂的报表还是构建用户界面,NVelocity 都是一个值得信赖的选择。

    SpringBoot学习笔记.docx

    这篇学习笔记将引导我们深入了解 SpringBoot 的基本用法,包括项目的创建、返回视图、数据库交互、前端与后端数据传递、日志管理和安全控制等方面。 1. **新建项目**: 创建 SpringBoot 项目通常是通过 Maven 或 ...

    模板引擎velocitye、nvelocitye手册

    Velocity 模板引擎是一种基于 Java 的强大工具,它主要用于将静态页面内容与动态数据结合起来,实现高度可定制和灵活的页面...通过熟练掌握 VTL 和 Velocity 的用法,开发者可以构建出高效、安全且易于维护的动态网站。

Global site tag (gtag.js) - Google Analytics