Apache Tiles 2.x 应用指南
JakartaTiles是一个用于在模板中对页面进行布局的框架。Tiles产生之初是Struts架构的一部分,后来Tiles独立出来常与Spring架构配合,本文描述了独立于其它架构而在原始WEB应用中使用Tiles的方法。
基本用法
设置Tiles元素-核心配置文件的书写方法
Tiles核心配置文件格式为xml,文档类型为tiles-definitions。要在每一个配置文件的开头加入下述说明:
<!DOCTYPE tiles-definitions PUBLIC "-//Apache Software Foundation//DTD Tiles Configuration 2.0//EN" "http://tiles.apache.org/dtds/tiles-config_2_0.dtd">
Tiles中的基本元素有三种:定义、模板和属性。Tiles核心配置文件(tiles-definitions)中的基本单元是“definition”。一个“definition”必须与一个“template”相对应。“template”是一个URI、通常情况下指的是一个JSP页面。一个“definition”可以包含多个“attribute”,一个attribute可以是一个字符串、可以是一个定义的名字、也可以是一个模板。
可以使用定义描述一个带有名字的模板。下例定义了一个没有属性的模板:
<tiles-definitions> <definition name="header" template="/fragments/header.jsp" /> </tiles-definitions>
模板可以包含一个或多个属性,属性可以是一个字符串,或者是一个定义的名字,或者是一个模板。下例定义了一个包含属性的模板:
<tiles-definitions>
<definition name="header" template="/fragments/header.jsp" />
<definition name="main" template="/index.jsp">
<put-attribute name="title" value="标题名" type="string"/>
<put-attribute name="header" value="header" type="definition"/>
<put-attribute name="footer" value="/fragments/footer.jsp" />
</definition>
</tiles-definitions>定义可以被继承,继承之后的定义属性可以改变,模板不可以改变。下例定义了一个具有继承关系的模板:
<tiles-definitions>
<definition name="header" template="/fragments/header.jsp" />
<definition name="main" template="/index.jsp">
<put-attribute name="title" value="主画面" type="string"/>
<put-attribute name="header" value="header" type="definition"/>
<put-attribute name="footer" value="/fragments/footer.jsp" />
</definition>
<definition name="user" extends="main">
<put-attribute name="title" value="新建用户" />
</definition>
</tiles-definitions> 读取Tiles元素-JSP页面上的处理方法
要想在JSP页面上使用Tiles标签,首先要引入标签库。
<%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles" %>
在JSP页面上插入一个模板的基本标签是<tiles:insertTemplate/>,如下例:
<tiles:insertTemplate template="/fragments/footer.jsp"/>
如果插入的模板包含属性,则在插入模板的同时,必须使用<tiles:putAttribute/>标签为其指定属性值:
<tiles:putAttributename="title"value="主画面"/>
<tiles:putAttributename="header"value="header"/>
<tiles:putAttributename="footer"value="/fragments/footer.jsp"/>
</tiles:insertTemplate>
插入一个定义的基本标签是<tiles:insertDefinition/>,如下例:
<tiles:insertDefinition name="main"/>
在模板中可以指定属性的位置。设置一个属性的基本标签有两种,如果属性被指定为定义或模板,则使用<tiles:insertAttribute/>标签;如果属性被指定为字符串,则使用<tiles:getAsString/>标签。如:
<tiles:getAsStringname="title"/>
<tiles:insertAttributename="header"/>
<tiles:insertAttributename="footer"/>
Tiles架构在各个领域中的应用
在Web应用中直接使用Tiles架构
在web.xml中加入下述servlet即可实现在Web应用中直接使用Tiles架构的目的。
<servlet>
<servlet-name>tiles</servlet-name>
<servlet-class>
org.apache.tiles.servlet.TilesServlet
</servlet-class>
<load-on-startup>2</load-on-startup>
</servlet>TilesServlet默认查找“/WEB-INF/tiles.xml”作为Tiles核心配置文件,如果要手动指定Tiles核心配置文件的位置,可以为Servlet设置名为“definitions-config”的初始化参数值,样例如下:
<servlet>
<servlet-name>tiles</servlet-name>
<servlet-class>
org.apache.tiles.servlet.TilesServlet
</servlet-class>
<init-param>
<param-name>definitions-config</param-name>
<param-value>
/WEB-INF/tiles-defs.xml
</param-value>
</init-param>
<load-on-startup>2</load-on-startup>
</servlet>在传统Servlet中利用TilesServlet加载的Tiles定义(definition)可以使用TilesContainer的render方法实现转向到Tiles定义。代码如下:
TilesContainer container = TilesAccess.getContainer(
request.getSession().getServletContext());
container.render("main", request, response);更多内容
关于Tiles的更多内容,如
ListAttributes
请参考Tiles官方网站:http://tiles.apache.org
Tiles知识要点
Tiles中的三大元素:定义、模板、属性
template=URI{1}
definition=template{1}+attribute*
attribute=STRING{1}|definition{1}|template{1}
Tiles核心配置文件
<!DOCTYPE tiles-definitions PUBLIC "-//Apache Software Foundation//DTD Tiles Configuration 2.0//EN" "http://tiles.apache.org/dtds/tiles-config_2_0.dtd">
引入Tiles标签库
<%@ taglib uri="http://tiles.apache.org/tags-tiles" prefix="tiles" %>
在Web应用中使用直接Tiles架构
在web.xml中关于Tiles架构的定义
<servlet>
<servlet-name>tiles</servlet-name>
<servlet-class>
org.apache.tiles.servlet.TilesServlet
</servlet-class>
<init-param>
<param-name>definitions-config</param-name>
<param-value>
/WEB-INF/tiles-defs.xml
</param-value>
</init-param>
<load-on-startup>2</load-on-startup>
</servlet>资源
http://tiles.apache.org/
JAR包
Tiles开发包
tiles-core-2.0.3.jar
tiles-api-2.0.3.jar
tiles-jsp-2.0.3.jar
Tiles所依赖的开发包
commons-beanutils-1.7.0.jar
commons-digester-1.8.jar
commons-logging-api-1.1.jar