页面装饰器框架-SiteMesh应用Decorator模式

通过SiteMesh的页面装饰,可以提高更好的代码复用,以下是配置使用的简单记录:

1.下载jar包:sitemesh-2.3.jar,将jar复制到lib目录下

2.web.xml文件中配置sitemesh的Filter

<!-- 配置装饰器filter -->
  <filter>
      <filter-name>sitemeshFilter</filter-name>
      <filter-class>com.opensymphony.sitemesh.webapp.SiteMeshFilter</filter-class>
  </filter>
  <filter-mapping>
      <filter-name>sitemeshFilter</filter-name>
      <url-pattern>/jsp/*</url-pattern>
  </filter-mapping>

3.新建一个decorators.xml文件:

<decorators defaultdir="/WEB-INF/jsp">
    
    <!-- 配置装饰器页面-->
    <decorator name="decorator" page="/jsp/decorator.jsp" >
        <!-- 配置需要追加装饰器的页面 -->
        <pattern>/jsp/*</pattern>
    </decorator>
    
    <!-- 配置不需要追加装饰的页面 -->
    <excludes>
        <pattern>/jsp/decorator*</pattern>
    </excludes>
</decorators>

4.新建装饰页面decorator.jsp

  1. <%@ page contentType="text/html;charset=UTF-8"%>
    <%@ include file="/WEB-INF/jsp/common/taglibs.jspf"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <body>  
  3.     <!--头部  -->  
  4.     <div align="center">  
  5.         <h1 >头部信息:   
  6.             <sitemesh:write property='title' />   
  7.         </h1>    
  8.     </div>  
  9.     <hr>     
  10.      
  11.     <!--左侧菜单栏  -->  
  12.     <div class="conbgbtm">  
  13.         <div class="leftbox">  
  14.             <ul>  
  15.                 <li><a href="#">菜单1</a></li>  
  16.                 <li><a href="#">菜单2</a></li>  
  17.                 <li><a href="#">菜单3</a></li>  
  18.             </ul>  
  19.         </div>  
  20.         <sitemesh:write property='body'></sitemesh:write>  
  21.     </div>  
  22.     <hr>  
  23.               
  24.     <div align="center">  
  25.         <span>Copyright © 2012-2013 廊坊信息技术提高班 版权所有</span>  
  26.     </div>  
  27.       
  28. </body>  
  29. </html>



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值