<?xml version="1.0" encoding="ISO-8859-1" ?>在<definition>卷标中,我们指定了版面配置的JSP页面,也就是path属性所指定的 myLayout.jsp,name属性表明这个版面配置的名称,而在接下来的<put>标签中,我们指定了内容页面的名称与JSP页面实际 的位置。
<!DOCTYPE tiles-definitions PUBLIC
"-//Apache Software Foundation//DTD Tiles Configuration 1.1//EN"
"http://jakarta.apache.org/struts/dtds/tiles-config_1_1.dtd">
<tiles-definitions>
<definition name=".myLayout" path="/tiles/myLayout.jsp">
<put name="title" value="Sample Page Title" />
<put name="header" value="/tiles/header.jsp" />
<put name="menu" value="/tiles/menu.jsp" />
<put name="footer" value="/tiles/footer.jsp" />
<put name="body" value="/tiles/body.jsp" />
</definition>
</tiles-definitions>
<?xml version="1.0" encoding="Big5" ?>其中myLayout.jsp的内容如下:
<!DOCTYPE tiles-definitions PUBLIC
"-//Apache Software Foundation//DTD Tiles Configuration 1.1//EN"
"http://jakarta.apache.org/struts/dtds/tiles-config_1_1.dtd">
<tiles-definitions>
<definition name=".myLayout" path="/tiles/myLayout.jsp">
<put name="title" value="Tiles范例" />
<put name="header" value="/tiles/header.jsp" />
<put name="menu" value="/tiles/menu.jsp" />
<put name="footer" value="/tiles/footer.jsp" />
<put name="body" value="/tiles/body.jsp" />
</definition>
</tiles-definitions>
<%@taglib prefix="tiles" uri="/tags/struts-tiles"%>这个版面配置网页中主要使用表格来切割版面,Tiles卷标可以从attribute属性得知对应于XML定义档的真正JSP页面,例如header将被 实际取代为header.jsp的内容,您可以自行完成其它的JSP页面内容。
<html>
<head>
<title><tiles:getAsString name="title"/></title>
</head>
<body>
<table border="0" width="100%" cellspacing="5">
<tr>
<td colspan="2">
<tiles:insert attribute="header"/>
</td>
<tr>
<tr>
<td width="140" valign="top">
<tiles:insert attribute="menu"/>
</td>
<td valign="top" align="left">
<tiles:insert attribute="body"/>
</td>
</tr>
<tr>
<td colspan="2">
<tiles:insert attribute="footer"/>
</td>
</tr>
</table>
</body>
</html>
<%@page contentType="text/html; charset=big5"%>在<tiles:insert>标签中指定我们将使用.myLayout的版面配置定义,如果您连上welcome.jsp,则实际上您 会看到以下的内容:
<%@taglib prefix="tiles" uri="/tags/struts-tiles"%>
<tiles:insert definition=".myLayout" flush="true"/>
<html> <head><title>Tiles范例</title></head> <body> <table border="0" width="100%" cellspacing="5"> <tr> <td colspan="2"> <center><h1>Tiles测试范例<h1> </td> <tr> <tr> <td width="140" valign="top"> 选单一<br> 选单二<br> 选单三<br> </td> <td valign="top" align="left"> Tiles提供一个类似于窗口程序版面管理的机制,透过定义档,您可 以定义版面配置,以及当中所要置入的内容网页,内容与版面配置的 标签可以分离,您可以随时抽换每一个内容网页,也可以重用每一个 版面配置。 </td> </tr> <tr> <td colspan="2"> <center>版权所有(c)http://www.caterpillar.onlyfun.net/ </td> </tr> </table> </body> </html>如果您将来要改变版面配置的方式,您可以直接修改tiles-defs.xml中path所指向的Layout页面,就如同您在窗口程序中改变版面管理员 一样,如果您要修改指向的内容网页,也只要更改tiles-defs.xml中相对应的设定,所有的更改集中于Tiles设定档中加以管理,达到将版面配 置与内容分离的目的。
<?xml version="1.0" encoding="big5" ?>
<!DOCTYPE tiles-definitions PUBLIC
"-//Apache Software Foundation//DTD Tiles Configuration 1.1//EN"
"http://jakarta.apache.org/struts/dtds/tiles-config_1_1.dtd">
<tiles-definitions>
<definition name=".myLayout" path="/tiles/myLayout.jsp">
<put name="title" value="Tiles范例" />
<put name="header" value="/tiles/header.jsp" />
<put name="menu" value="/tiles/menu.jsp" />
<put name="footer" value="/tiles/footer.jsp" />
<put name="body" value="/tiles/body.jsp" />
</definition>
<definition name=".myLayout2" extends=".myLayout">
<put name="title" value="Tiles范例二" />
<put name="header" value="/tiles/header2.jsp" />
</definition>
</tiles-definitions>
在上面的定义中,.myLayout2扩充自.myLayout,并重新定义了title与header两个属性,其它未重新定义的属性将直接继承自.
myLayout。