一:說(shuō)明
Struts1.1以后增加了Tiles包使得struts在頁(yè)面的處理方面多了一種選擇.并且更容易實(shí)現(xiàn)代碼的重用。Tiles中對(duì)頁(yè)面的劃分有點(diǎn)象jakarta的另外一個(gè)項(xiàng)目Turbine中的TDK。增加了layout的概念.其實(shí)就是把一個(gè)頁(yè)面劃分為幾塊。通常的來(lái)說(shuō)一個(gè)頁(yè)面大概可以劃分為如下幾塊:head頁(yè)面頭部:存放一個(gè)運(yùn)用的公共信息:logo等,如果是網(wǎng)站可能是最上面的一塊.menu頁(yè)面菜單:放置一個(gè)運(yùn)用中需要使用的菜單,或者在每一個(gè)頁(yè)面都使用的連接.footer頁(yè)面尾部:如版權(quán)信息等.body頁(yè)面主題內(nèi)容:每個(gè)頁(yè)面相對(duì)獨(dú)立的內(nèi)容.如果按上面的劃分那對(duì)每一個(gè)頁(yè)面我們只要寫body里面的內(nèi)容,其他的就可以共享重用.如果大多數(shù)頁(yè)面的布局基本相同我們甚至可以使用一個(gè)jsp文件根據(jù)不同的參數(shù)調(diào)用不同的body.
二:Tiles配置和基本配置文件介紹
Tiles有一個(gè)配置文件:tiles-defs.xml
tiles-defs.xml定義了每一個(gè)頁(yè)面的組成元素和形式。
下面我將說(shuō)明如下所示的一個(gè)tiles-defs.xml文件
tiles-defs.xml
-----------------------------------------------
<tiles-definitions>
<!--定義/layouts/classicLayout.jsp的組成名稱為site.mainLayout-->
<!--后面將附/layouts/classicLayout.jsp的內(nèi)容-->
<definition name="site.mainLayout" path="/layouts/classicLayout.jsp">
<put name="title" value="Tiles Blank Site" />
<put name="header" value="/tiles/common/header.jsp" />
<put name="menu" value="site.menu.bar" />
<!--menu的組成為site.menu.bar對(duì)應(yīng)的頁(yè)面-->
<put name="footer" value="/tiles/common/footer.jsp" />
<put name="body" value="/tiles/body.jsp" />
</definition>
<!--定義site.index.page,繼承site.mainLayout-->
<definition name="site.index.page" extends="site.mainLayout" >
<put name="title" value="Tiles Blank Site Index" />
<put name="body" value="/tiles/body.jsp" />
<!--以上兩個(gè)元素將替換site.mainLayout中的元素-->
</definition>
<definition name="site.menu.bar" path="/layouts/vboxLayout.jsp" >
<putList name="list" >
<add value="site.menu.links" />
<add value="site.menu.documentation" />
</putList>
</definition>
</tiles-definitions>
附:/layouts/classicLayout.jsp
--------------------------------
<html>
<head>
<title><tiles:getAsString name="title"/>
</title>
</head>
<body bgcolor="#ffffff" text="#000000" link="#023264" alink="#023264" vlink="#023264">
<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>
在web.xml里面配置tiles,配置完后對(duì)應(yīng)struts action servlet的配置如下:
web.xml
-----------------
<!-- Action Servlet Configuration -->
<servlet>
<servlet-name>action</servlet-name>
<!-- Specify servlet class to use:
- Struts1.0.x: ActionComponentServlet
- Struts1.1: ActionServlet
- no Struts: TilesServlet
-->
<servlet-class>org.apache.struts.action.ActionServlet</servlet-class>
<!-- Tiles Servlet parameter
Specify configuration file names. There can be several comma
separated file names
-->
<init-param>
<param-name>definitions-config</param-name>
<param-value>/WEB-INF/tiles-defs.xml</param-value>
</init-param>
<!-- Tiles Servlet parameter
Specify Tiles debug level.
O : no debug information
1 : debug information
2 : more debug information
-->
<init-param>
<param-name>definitions-debug</param-name>
<param-value>1</param-value>
</init-param>
<!-- Tiles Servlet parameter
Specify Digester debug level. This value is passed to Digester
O : no debug information
1 : debug information
2 : more debug information
-->
<init-param>
<param-name>definitions-parser-details</param-name>
<param-value>0</param-value>
</init-param>
<!-- Tiles Servlet parameter
Specify if xml parser should validate the Tiles configuration file.
true : validate. DTD should be specified in file header.
false : no validation
-->
<init-param>
<param-name>definitions-parser-validate</param-name>
<param-value>true</param-value>
</init-param>
<!-- Struts configuration, if Struts is used -->
<init-param>
<param-name>config</param-name>
<param-value>/WEB-INF/struts-config.xml</param-value>
</init-param>
<init-param>
<param-name>validate</param-name>
<param-value>true</param-value>
</init-param>
<init-param>
<param-name>debug</param-name>
<param-value>2</param-value>
</init-param>
<init-param>
<param-name>detail</param-name>
<param-value>2</param-value>
</init-param>
<load-on-startup>2</load-on-startup>
</servlet>
三:使用Tiles
如果已經(jīng)配置好tiels-defs.xml,接下來(lái)就可以在jsp文件中使用這些定義了。
有如下的方式使用tiles
3.1:
<tiles:insert definition="site.mainLayout" flush="true" />
插入site.mainLayout標(biāo)記的一頁(yè)
3.2:
<tiles:insert template="/tutorial/basic/myFramesetLayout.jsp" >
<tiles:put name="title" content="My first frameset page" direct="true" />
<tiles:put name="header" content="/tutorial/common/header.jsp" direct="true"/>
<tiles:put name="footer" content="/tutorial/common/footer.jsp" direct="true"/>
<tiles:put name="menu" content="/tutorial/basic/menu.jsp" direct="true"/>
<tiles:put name="body" content="/tutorial/basic/helloBody.jsp" direct="true"/>
</tiles:insert>
/tutorial/basic/myFramesetLayout.jsp
---------------------------------
<html>
<head>
<title><tiles:get name="title"/></title>
</head>
<frameset rows="73, *, 73">
<frame src="<%=request.getContextPath()%><tiles:get name="header" />" name="header" >
<frame src="<%=request.getContextPath()%><tiles:get name="body" />" name="body" >
<frame src="<%=request.getContextPath()%><tiles:get name="footer" />" name="footer" >
</frameset>
</html>
插入/tutorial/basic/myFramesetLayout.jsp
并把title的值設(shè)定為:My first frameset page
header設(shè)定為/tutorial/common/header.jsp
四:后記
Tiles的使用在他的文檔里面寫的比較詳細(xì)。以上是一些簡(jiǎn)單和基本的使用。具體的文檔可以看Struts里面的一個(gè)tiles-documentation.war的包。但即使是這個(gè)包也不是很全??梢酝ㄟ^(guò)上的的連接到作者的主頁(yè)上去找。個(gè)人覺(jué)得使用Tiles在做企業(yè)運(yùn)用的時(shí)候可能不如在做網(wǎng)站那樣更能體現(xiàn)優(yōu)越性。但在系統(tǒng)開始設(shè)計(jì)的時(shí)候考慮并規(guī)劃好整個(gè)UI,那在修改和維護(hù)的時(shí)候?qū)⒐?jié)省不少的工作量,因?yàn)橥ǔI的確定在代碼編寫結(jié)束和完成,所有盡可能的使用多個(gè)子頁(yè)面構(gòu)成一個(gè)頁(yè)面,后面的美化和維護(hù)就比直接維護(hù)一個(gè)很大的頁(yè)面容易