Velocity布局祥解

大多数网站的每个页面布局差别不是太大,除非一些特殊页面例如 门户首页等。如果每个页面独立一个文件,则会导致不同文件出现大量相同的代码,我们也可以把这些相同的代码抽取出来放在一个独立的小文件,需要的时候利用 Velocity的#parse指令来嵌入到目标页面中。但是此法却对页面上用于控制排版的HTML代码无效,因为控制整个页面排版的代码一般会贯穿整个 文件,开头、结尾皆有,无法分拆到独立的文件上,因此就有将页面的layout独立出来的,以减小页面的代码量的需要。

我在用Velocity时一般都是使用Velocity-Tools项目的VelocityViewServlet来负责解析所有Velocity 模板的请求,其实VelocityTools也提供另外一个Servlet便是VelocityLayoutServlet,该类直接从 VelocityViewServlet继承而来,通过使用VelocityLayoutServlet可以让我们很容易的将页面的布局控制模板和数据模 板分隔开来。欲使用此功能,请遵循以下步骤:

1。使用VelocityLayoutServlet类:原先的VelocityViewServlet直接替换成 VelocityLayoutServlet;

2。配制VelocityLayoutServlet:打开velocity.properties增加配制如下:

01 #  处理错误信息的模板路径
02 #  relative to web application root directory
03 tools.view.servlet.error.template = error.vm
04  
05 #  所有布局文件的默认路径
06 #  relative to web application root directory
07 tools.view.servlet.layout.directory = /WEB-INF/layout/
08  
09 #  默认的布局文件
10 #  relative to the layout directory
11 #  NOT relative to the root directory of the webapp!
12 tools.view.servlet.layout.default.template =  default.vm

3。布局测试

编写测试布局文件default.vm放置于上述配置中的默认布局文件存放路径中,内容如下

1 <html>
2 <head>
3   <title>$!page_title</title>
4 </head>
5 <body>
6   $screen_content
7 </body>
8 </html>

上面源码中$screen_content便是VelocityLayoutServlet保留的关键字,Velocity依此关键字来潜入实际被 引用的页面内容,其他变量开发者可以灵活处理。

另编写测试页面test.vm存放于web根目录下,内容如下

1 #set($page_title="Layout Test")
2 Hello Velocity Layout!

启动服务器,测试该页面输出的HTML内容如下:

1 <html>
2 <head>
3   <title>Layout Test</title>
4 </head>
5 <body>
6   Hello Velocity Layout!
7 </body>
8 </html>

如此便达到我们预期的效果,如何使用便是听凭各位发落:)

参考资料:

http://jakarta.apache.org/velocity/tools/view/layoutservlet.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值