SiteMesh页面装饰器的使用步骤

SiteMesh 是一个网页布局和修饰的框架,利用它可以将网页的内容和页面结构分离,以达到页面结构共享的目的

SiteMesh是OpenSymphony团队开发的JEE框架之一,它是一个非常优秀的页面装饰器框架,它通过对所有的用户请求进行过滤,并对服务器向客户端响应也进行过滤,从而给原始的服务器响应加入一定的装饰,可以是header,footer等,然后将经过装饰后的页面送回浏览者.对于被装饰的页面而言,它无需知道自身被谁装饰,也无从知道自身被谁装饰,SiteMesh通过配置文件来配置指定的装饰器,用于过滤某些页面,则该装饰器会装饰这些页面,从而提供更好的页面效果,通过SiteMesh的页面装饰,可以提供更好的代码复用,所有的页面装饰效果耦合在目标页面中,无需使用include指令来显式包含装饰效果,目标页面与装饰页面完全分高.提供更好的解耦,而且可以应用中所有的页面都使用相同的装饰页面,整个Web应用会有更统一的风格,会提供更好的整体效果.

SiteMesh通过Filter来截取request和response,然后给原始的页面加入一定的装饰,再把结果返回给客户端.



目录结构:



1、往j2ee项目中添加SiteMesh开发包

下载地址:http://pan.baidu.com/s/1kTA76sB


2、在web.xml中添加SiteMesh 的配置文件

[html]  view plain  copy
  1. <filter>  
  2.     <filter-name>sitemeshFilter</filter-name>  
  3.     <filter-class>com.opensymphony.sitemesh.webapp.SiteMeshFilter</filter-class>  
  4.   </filter>  
  5.   <filter-mapping>  
  6.     <filter-name>sitemeshFilter</filter-name>  
  7.     <url-pattern>/*</url-pattern>  
  8.   </filter-mapping>  

3、创建一个decorators.xml在WEB-INF下

[java]  view plain  copy
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <decorators defaultdir="/WEB-INF/views">  
  3.     <!-- 默认装饰页面, 在需要装饰的页面增加<meta name="decorator" content="default"/> -->  
  4.     <decorator name="default" page="layouts/default.jsp" />  
  5.     <!-- 下面可以写多个 -->  
  6.       
  7. </decorators>  

4、在defaultdir对应的目录下创建html(也可以是jsp),如:取名为default.jsp

5、将default.jsp配置成装饰器,并告诉SiteMesh什么样的路径将使用该装饰器

[java]  view plain  copy
  1. <%@ page contentType="text/html;charset=UTF-8"%>  
  2. <%@ include file="/WEB-INF/views/inc/taglibs.jsp"%>  
  3. <%@ taglib prefix="sitemesh" uri="http://www.opensymphony.com/sitemesh/decorator" %>  
  4. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
  5. <html>  
  6. <head>  
  7.     <title>  
  8.         <sitemesh:title default="XXX"></sitemesh:title>--管理系统  
  9.     </title>  
  10.     <%@include file="/WEB-INF/views/inc/meta.jsp" %>  
  11.     <sitemesh:head/>  
  12. </head>  
  13. <body>  
  14. <jsp:include page="/WEB-INF/views/inc/header.jsp" />  
  15. <div class="container-fluid">  
  16.     <div class="row">  
  17.         <div class="col-md-2 left">  
  18.             <jsp:include page="/WEB-INF/views/inc/left.jsp" />  
  19.          </div>  
  20.         <div class="col-md-10">  
  21.             <sitemesh:body/>  
  22.         </div>      
  23.     </div>  
  24. </div>  
  25. </body>  
  26. </html>  

6、建立一个index.jsp使用装饰器

在<head>标签中引用<meta name="decorator" content="default"/>  即可

[java]  view plain  copy
  1. <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>  
  2. <%@ include file="inc/taglibs.jsp" %>  
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
  4. <html>  
  5. <head>  
  6.     <title>管理系统</title>  
  7.     <meta name="decorator" content="default"/>  
  8. </head>  
  9. <body>  
  10.     hello world  
  11. </body>  
  12. </html>  

7、这样就基本上配置完成了,以后所有的页面就不需要写一些不变的(如一个网站的头部,左部,下部),只关注右边

      以后在页面中只需要引入<meta name="decorator" content="default"/>  ,SiteMesh就会自动把头部,左部,下部装饰到你写的页面中。这样就可以再你建立的jsp页面中

<body>标签内写你自己的代码了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值