SpringMVC整合Tiles框架

Tiles组件

tiles-iconfig.xml

Tiles是一个JSP布局框架。

Tiles框架为创建Web页面提供了一种模板机制,它能将网页的布局和内容分离。它用模板定义网页布局,每个页面模板都是一个简单的 JSP 页,它定义了一些由占位符组成的外形,以放置内容。执行时,Tiles 将会用相应的内容来替换占位符,因此,创建整个页面即形成布局。Tiles框架是建立在JSP的include指令基础上的,但它提供了比JSP的include指令更强大的功能。Tiles框架具有如下特性:

1.         创建可重用的模板

2.         动态构建和装载页面

3.         定义可重用的Tiles组件

4.         支持国际化。

接下来就介绍Tiles框架的基本使用。

<tiles-definitions>标签内主要的子节点就是<definition>标签,这个标签属性如下:

属性

名称

是否必须

值必须

值类型

说明

name

true

true

java.lang.String

指定将要创建的一个definition bean的访问名称。这个必须有的。

template

false

true

java.lang.String

哪一个文件是模板文件,这个模板文件后面会介绍。

role

false

true

java.lang.String

如果配置了这个值的话,需要role的值相等,这个definition才被有效访问,这个功能我没有深究,也不推荐使用,建议大家建立自己更完善的权限控制管理。当然欢迎朋友们完善role应用的示例,tiles自带role的示例,有兴趣的人去读一下就明白了。

extends

false

true

java.lang.String

继承哪一个definition,值是你要继承的definition的name的值。高使用率的属性。

preparer

false

true

java.lang.String

呵,我没使用,如果你要使用的话,要写一个实现他的Prepare接口的类,作用就是在展现你定义的页面前会先执行你的prepare。

应用程序布局

我们的目标是我们Spring3HelloWorld应用程序添加页眉,页脚和菜单。以下将是相同的布局。

所需JAR包

上述表中突出显示的jar文件要添加新的Tiles集成项目。

在Spring mvc 中配置Tiles框架

要配置Tiles,在spring-servlet.xml中配置一个TilesConfig的<bean>。打开spring-servlet.xml,并添加下面的代码<beans></beans>标记之间。

WEB-INF/spring-servlet.xml:
1 <bean id="viewResolver" 
2     class="org.springframework.web.servlet.view.UrlBasedViewResolver"> 
3     <property name="viewClass"> 
4         <value> 
5             org.springframework.web.servlet.view.tiles2.TilesView 
6         </value> 
7     </property> 
8 </bean> 
9 <bean id="tilesConfigurer" 
10     class="org.springframework.web.servlet.view.tiles2.TilesConfigurer"> 
11     <property name="definitions"> 
12         <list> 
13             <value>/WEB-INF/tiles.xml</value> 
14         </list> 
15     </property> 
16 </bean>

通过上面定义的参数.在WEB-INF中写一个tiles的配置文件"tiles.xml"这个xml为我们的web项目定义Tiles

WEB-INF/tiles.xml:

1 <?xml version="1.0" encoding="UTF-8" ?> 
2 <!DOCTYPE tiles-definitions PUBLIC 
3        "-//Apache Software Foundation//DTD Tiles Configuration 2.0//EN" 
4        "http://tiles.apache.org/dtds/tiles-config_2_0.dtd"> 
5 <tiles-definitions> 
6     <definition name="base.definition" 
7         template="/WEB-INF/jsp/layout.jsp"> 
8         <put-attribute name="title" value="" /> 
9         <put-attribute name="header" value="/WEB-INF/jsp/header.jsp" /> 
10         <put-attribute name="menu" value="/WEB-INF/jsp/menu.jsp" /> 
11         <put-attribute name="body" value="" /> 
12         <put-attribute name="footer" value="/WEB-INF/jsp/footer.jsp" /> 
13     </definition> 
14   
15     <definition name="contact" extends="base.definition"> 
16         <put-attribute name="title" value="Contact Manager" /> 
17         <put-attribute name="body" value="/WEB-INF/jsp/contact.jsp" /> 
18     </definition> 
19   
20 </tiles-definitions>

在这里,我们有tiles.xml定义模板base.definition。该布局包含的属性,如头,标题,主体,菜单和页脚。然后扩展和布局的新关联页面。我们覆盖默认的布局改变Body和Title的内容。

创建我们的JSP文件

我们写一个layout.jsp作为我们web项目的布局页面然后引入相应的页面

WEB-INF/jsp/layout.jsp
1 <%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles"%> 
2 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
3 "http://www.w3.org/TR/html4/loose.dtd"> 
4 <html> 
5 <head> 
6 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 
7 <title><tiles:insertAttribute name="title" ignore="true" /></title> 
8 </head> 
9 <body> 
10 <table border="1" cellpadding="2" cellspacing="2" align="center"> 
11     <tr> 
12         <td height="30" colspan="2"><tiles:insertAttribute name="header" /> 
13         </td> 
14     </tr> 
15     <tr> 
16         <td height="250"><tiles:insertAttribute name="menu" /></td> 
17         <td width="350"><tiles:insertAttribute name="body" /></td> 
18     </tr> 
19     <tr> 
20         <td height="30" colspan="2"><tiles:insertAttribute name="footer" /> 
21         </td> 
22     </tr> 
23 </table> 
24 </body> 
25 </html> 
 
WEB-INF/jsp/header.jsp
26 <h1>Header</h1> 
WEB-INF/jsp/menu.jsp
27 <span style="font-size: 14px;"><p>Menu</p></span> 
WEB-INF/jsp/footer.jsp
<span style="font-size: 14px;"><p>Copyright <code class="xml plain">©</code>Zemo.com</p></span>
所有工作准备就绪部署就行了

最新文章

  1. maven 私服搭建
  2. 一次Debug过程的思考
  3. 【BZOJ-3638&amp;3272&amp;3267&amp;3502】k-Maximum Subsequence Sum 费用流构图 + 线段树手动增广
  4. 检查字符串长度 检查字符串是否为空 用正则表达式验证出版物的ISBN号 用正则表达式验证邮证编码 验证字符串中是否含有汉字
  5. 使用webView制作浏览器
  6. [置顶] 浅谈Android的资源编译过程
  7. AMDU恢复ASM磁盘组数据(測)
  8. 2016年BAT公司常见的Web前端面试题整理
  9. 进程池爬取并存入mongodb
  10. Solr全文检索框架
  11. tcl脚本直接执行脚本中中文识别不了的处理
  12. 使用xshell连接服务器,数字键盘无法使用解决办法
  13. android获取sd卡路径方法
  14. java 遍历Map的四种方式
  15. 2018.09.11 poj2976Dropping tests(01分数规划)
  16. GBDT分类和回归例子
  17. HDU中大数实现的题目,持续更新(JAVA实现)
  18. cmd 导出导入数据库
  19. python 线程/进程模块
  20. html的body内标签之input系列1

热门文章

  1. 数据可视化工具zeppelin安装
  2. 夺命雷公狗ThinkPHP项目之----企业网站9之栏目的列表完善(无限极分类的完成)
  3. 夺命雷公狗jquery---6属性选择器
  4. Immediate assertion
  5. delphi 读取excel 两种方法
  6. PAT乙级 1022. D进制的A+B (20)
  7. USB HID描述符【转】
  8. iOS 学习笔记 十三 (2015.04.15)采用第三方库,实现ios录音转为amr
  9. React笔记_(7)_react路由
  10. java中使用反射往一个泛型是Integer类型的ArrayList中添加字符串,反射的案例1.