服务热线:13616026886

技术文档 欢迎使用技术文档,我们为你提供从新手到专业开发者的所有资源,你也可以通过它日益精进

位置:首页 > 技术文档 > JAVA > 新手入门 > 基础入门 > 查看文档

struts‘stiles使用入门完全攻略


  一:说明
  struts1.1以后增加了tiles包使得struts在页面的处理方面多了一种选择.并且更容易实现代码的重用。tiles中对页面的划分有点象jakarta的另外一个项目turbine中的tdk。增加了layout的概念.其实就是把一个页面划分为几块。通常的来说一个页面大概可以划分为如下几块:head页面头部:存放一个运用的公共信息:logo等,如果是网站可能是最上面的一块.menu页面菜单:放置一个运用中需要使用的菜单,或者在每一个页面都使用的连接.footer页面尾部:如版权信息等.body页面主题内容:每个页面相对独立的内容.如果按上面的划分那对每一个页面我们只要写body里面的内容,其他的就可以共享重用.如果大多数页面的布局基本相同我们甚至可以使用一个jsp文件根据不同的参数调用不同的body.
  
  二:tiles配置和基本配置文件介绍
  tiles有一个配置文件:tiles-defs.xml
  tiles-defs.xml定义了每一个页面的组成元素和形式。
  下面我将说明如下所示的一个tiles-defs.xml文件
  tiles-defs.xml
  -----------------------------------------------
  <tiles-definitions>
  <!--定义/layouts/classiclayout.jsp的组成名称为site.mainlayout-->
  <!--后面将附/layouts/classiclayout.jsp的内容-->
  <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对应的页面-->
  <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" />
  <!--以上两个元素将替换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,配置完后对应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
  如果已经配置好tiels-defs.xml,接下来就可以在jsp文件中使用这些定义了。
  有如下的方式使用tiles
  3.1:
  <tiles:insert definition="site.mainlayout" flush="true" />
  插入site.mainlayout标记的一页
  
  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的值设定为:my first frameset page
  header设定为/tutorial/common/header.jsp
  
  四:后记
  tiles的使用在他的文档里面写的比较详细。以上是一些简单和基本的使用。具体的文档可以看struts里面的一个tiles-documentation.war的包。但即使是这个包也不是很全。可以通过上的的连接到作者的主页上去找。个人觉得使用tiles在做企业运用的时候可能不如在做网站那样更能体现优越性。但在系统开始设计的时候考虑并规划好整个ui,那在修改和维护的时候将节省不少的工作量,因为通常ui的确定在代码编写结束和完成,所有尽可能的使用多个子页面构成一个页面,后面的美化和维护就比直接维护一个很大的页面容易

扫描关注微信公众号