只需2分钟,简单构建velocity web项目
2014-10-08 21:35
302 查看
Velocity是一个基于java的模板引擎(template engine)。它允许任何人仅仅简单的使用模板语言(template language)来引用由java代码定义的对象
velocity的语法非常简单。这里不多介绍。
我们平时的web项目,通常的开发流程是前端写好静态页面。后端将静态页面改成jsp,在相应的需要替换数据的地方,使用 jstl、EL表达式等接收action模块传递过来的数据。一般使用action来处处理参数,调用service层来处理业务逻辑,service层调用dao层从数据库取数据。我们可以看到,大体上就是后端发送数据给前端。
这里一般会有一个很大的问题。如果业务变更,例如一个页面本来要显示一个表格,现在需要显示3个表格,另外的2个表格是从之前的其他页面合并的。mvc模式的好处就是,此时,除了页面的改动之外,做业务逻辑处理的service层和dao层,都不需要变化,只需要改动相应的action层,调用所需的service模块,将所需要的数据输出。
而如果使用velocity,除了页面的改动之外,其他都不需要改动。
velocity做web项目与我们平时的项目最大的不同是由前端从后端拿数据。需要什么就拿什么。我们完全可以通过velocity把前端和后端完全分离开来。
下面使用一个简单的例子模拟一下velocity的这种思想。
(由于velocity自身并不提供任何web相关的功能,它只是通过模板生成格式文档。但是,开发web应用的时候,需要有一个框架来处理HTTP请求。velocity有一个非常好的子项目velocity-tools,使用它的VelocityViewServlet可以非常方便的实现这个功能。如下)
1、依赖包只有2个:最新的 velocity-1.6.2.jar 和 velocity-tools-2.0.jar,网址:http://velocity.apache.org/download.cgi
2、首先看一下我们的web.xml
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd"> <web-app> <servlet> <servlet-name>velocity</servlet-name> <servlet-class>org.apache.velocity.tools.view.VelocityViewServlet</servlet-class> <init-param> <param-name>org.apache.velocity.toolbox</param-name> <param-value>/WEB-INF/conf/velocity-toolbox.xml</param-value> </init-param> <load-on-startup>3</load-on-startup> </servlet> <servlet-mapping> <servlet-name>velocity</servlet-name> <url-pattern>*.vm</url-pattern> </servlet-mapping> <welcome-file-list> <welcome-file>index.vm</welcome-file> </welcome-file-list> </web-app>
3、然后看一下简单的页面:
<html> <body> this is the word : $mytool.getHello() </body> </html>
4、接下来是最重要的velocity-toolbox.xml 类,这里的工具类就是在页面可以直接调用的类了。如下:
<?xml version="1.0" encoding="UTF-8"?> <toolbox> <tool> <key>mytool</key> <scope>request</scope> <class>com.chandler.tool.MyTool</class> </tool> </toolbox>
指定了请求到来时的工具类实例的生命周期为request
5、OK,就这样,可以访问了,如下:
可以看到,velocity的这种特性,使得它开发小型的网站变得非常便捷!很大的提高了开发效率!
如果文中有什么不对的地方,欢迎指正!谢谢!
转载请注明出处:/article/6010095.html 谢谢!
相关文章推荐
- 使用spring 4.0 + maven 构建超简单的web项目
- webpack 构建简单的vue项目
- 使用spring 4.0 + maven 构建超简单的web项目
- eclipse 使用maven 构建springbooot+mysql +freemarker 简单web 项目
- 在IDEA中简单使用Maven构建web项目
- webpack+vue+vueRouter+es6 构建的简单实例项目
- 使用spring 4.0 + maven 构建超简单的web项目
- 为您的Web项目构建一个简单的JSON控制器
- 新手教你学Spring4.0+Maven构建超级简单的Web项目(三)
- webpack 1.x构建react项目简单配置
- 新手教你学Spring4.0+Maven构建超级简单的Web项目(二)
- eclipse 使用maven 构建web项目 简单例子
- Eclipse+Maven构建简单Web项目
- 新手教你学Spring4.0+Maven构建超级简单的Web项目(一)
- eclipse maven 构建简单的web项目
- vuex在vue-cli和webpack构建的项目中的简单使用
- 使用Ant构建简单项目
- 做java web 开发的简单项目必须具备的知识——供新手参考
- 成功在 FreeMarker 网站上增加了 VelocityWeb 项目介绍!
- VS2005 Web项目安装部署:利用预编译的Dll 隐藏.cs文件 的简单实现