`
newleague
  • 浏览: 1474917 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类

Struts1 tiles笔记

阅读更多

Tiles标签库

Tiles标签的<tiles:insert>标签和jsp include 指令具有相同的功能。
<tiles:insert page="indexContent.jsp" flush="true"/>
flush为true,表示执行插入之前,先调用当前页面的输出流的flush()方法;

使用tiles标签的步骤
(1)安装tiles标签库需要的文件:
 WEB-INF/lib中包含:struts.jar ;commons-digester.jar commons-beanutils.jar commons-collections.jar commons-logging.jar
 (2) web.xml
 <taglib>
  <taglib-uri></taglib-uri>
  <taglib-location></taglib-location>
 </taglib>
 (3)创建页面,<%@ taglib uri=“” prefix="">引入标签库;

确定,框架代码仍然重复很多;

采用 tiles模板
使用tiles模板的步骤
(1)安装tiles标签所需要的文件
(2)在web。xml中配置<taglib>
(3)定义模板文件
 在需要变换的地方,即动态加载的部分,使用<tiles:insert attribute="***"/>
 attribute属性指定了 待插入内容的逻辑名,而没有指定真正被插入的文件;
(4)在动态加载的页面中运用tiles模板
 <tiles:insert page="layout.jsp" flush="true">
  <tiles:put name="sidebar" value=""/> <!--name对应上步中的attribute-->
  <tiles:put name="header" value=""/>
  <tiles:put name="content" value="**.jsp"/><!--这里为动态加载的部分,不同的页面就不同;-->
  <tiles:put name="footer" value=""/>
</tiles:insert>

不同的页面中除content变换,其他都不变,仍然可以再简化;

 Tiles组件
Tiles组件可以代表一个完整的网页,也可以代表网页的一部分。
简单的tiles组件可以组合成复杂的tiles组件,或被扩展为复杂的tiles组件;

使用方法
tiles框架在专门的xml文件中配置tiles组件。
例如:
 <tiles-definitions>
  <definition name="index-definition" path="/layout.jsp">

 <!--name属性指定了tiles组件名字; path为模板-->
   <put name="sidebar" value="sidebar.jsp"/>
   <put name="header" value="header.jsp"/>
   <put name="content" value="indexContent.jsp"/>
   <put name="footer" value="footer.jsp"/>
  </definition>
 </tiles-definitions>
步骤
(1)安装tiles标签库所需的文件;
(2)web.xml文件中配置<taglib〉元素;
(3)在专门的xml中配置tiles组件,设文件名为tiles-defs.xml; 放置在WEB-INF目录下;
(4)在struts-config.xml文件中配置 tiles-plugin插件;
 <plug-in className="org.apache.struts.tiles.TilesPlugin">
  <set-property property="definitions-config" value="/WEB-INF/tiles-defs.xml"/><!-如果有多个,用,号分割-->
  <set-property property="definitions-parser-validate" value="true"/>
 </plug-in>
(5)web.xml中配置actionservlet;
 <servlet>
  <servlet-name>action</servlet-name>
  <servlet-class>org.apache.struts.action.ActionServlet</servlet-class>
  <init-param>
   <param-name>config</param-name>
   <param-value>/WEB-INF/struts-config.xml</param-name>
  </init-param>
  <load-on-startup>3</load-on-startup>
 </servlet>
 <servlet-mapping>
  <servlet-name>action</servlet-name>
  <url-pattern>*.do</url-pattern>
 </servlet-mapping>
(6)在index.Jsp中插入tiles组件
 如<tiles:insert definition="index-definition"/>

如果tiles里面的某个definition代表一个完整的网页,那么可以在struts-config.xml中直接映射;
例如
 <action-mappings>
  <action path="/index" type="org.apache.struts.actions.ForwardAction" parameter="index=definition"/>
 </action-mappings>

 

tiles组件的组合;
<tiles-definitions>
 <definition name="sidebar-definition" path="/sidebar-layout.jsp">
  <put name="top" value="flags.jsp"/>
  <put name="bottom" value="sidebar-links.jsp"/>
 </definition>

 <definition name="index-definition" path="/layout.jsp">
  <put name="sidebar" value="sidebar-definition" type="definition"/>
  <put name="header" value="header.jsp"/>

  <put name="content" value="indexContent.jsp"/><!--页面1-->

  <put name="footer" value="footer.jsp"/>
  ......
 </definition>

 <definition name="product-definition" path="/layout.jsp">
  <put name="sidebar" value="sidebar-definition" type="definition"/>
  <put name="header" value="header.jsp"/>

  <put name="content" value="productContent.jsp"/><!--页面2-->

  <put name="footer" value="footer.jsp"/>

  ......
 </definition>
......
</tiles-definitions>

 

tiles组件的扩展:
 
先定义一个包含公共内容的base-definition组件,然后再让动态加载的页面的tiles组件继承这个父类;

<tiles-definitions>
 <definition name="sidebar-definition" path="/siderbar-layout.jsp">
  <put name="top" value="flags.jsp"/>
  <put name="bottomf" value="sidebar-links.jsp"/>
 </definition>
 <definition name="base-definition" path="/layout.jsp">
  <put name="sidebar" value="sidebar-definition" type="definition"/>
  <put name="header" value="header.jsp"/>
  <put name="content" value=""/>
  <put name="footer" value="footer.jsp"/> 
 </definition>
 <definition name="index-definition" extends="base-definition">
  <put name="content" value="indexContent.jsp"/> <!--页面1-->
 </definition>

 <definition name="product-definition" extends="base-definition">
  <put name="content" value="productContent.jsp"/><!--页面2-->
 </definition>
</tiles-definitions>

 

siderbar-layout.jsp

<table>
 <tr>
  <tiles:insert attribute="top"/>
 </tr>
 <tr>
  <tiles:insert attribute="bottom"/>
 </tr>
</table>

layout.jsp
<html>
 <head></head>
 <body>
  <table>
   <tr> 
    <td> <tiles:insert attribute="siderbar"/></td>
    <td>
     <table>
      <tr>
       <td><tiles:insert attribute="header"/></td>
      </tr>
      <tr>
       <td><tiles:insert attribute="content"/></td>
      </tr>
      <tr>
       <td><tiles:insert attribute="footer"/></td>
      </tr>

     </table>
    </td>

   </tr>
  </table>
 </body>
</html>

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics