最近公司做项目,需要用到SiteMesh框架,坦白的说之前没怎么用过,所以在网上查看了许多相关资料,自己总结了一下
最近公司做项目,需要用到SiteMesh框架,坦白的说之前没怎么用过,所以在网上查看了许多相关资料,自己总结了一下,希望对大家有所帮助。 本文来自织梦
SiteMesh是OpenSymphony团队开发的JEE框架之一,它是一个非常优秀的页面装饰器框架,它通过对所有的用户请求进行过滤,并对服务器向客户端响应也进行过滤,从而给原始的服务器响应加入一定的装饰,可以是header,footer等,然后将经过装饰后的页面送回浏览者.对于被装饰的页面而言,它无需知道自身被谁装饰,也无从知道自身被谁装饰,SiteMesh通过配置文件来配置指定的装饰器,用于过滤某些页面,则该装饰器会装饰这些页面,从而提供更好的页面效果,通过SiteMesh的页面装饰,可以提供更好的代码复用,所有的页面装饰效果耦合在目标页面中,无需使用include指令来显式包含装饰效果,目标页面与装饰页面完全分高.提供更好的解耦,而且可以应用中所有的页面都使用相同的装饰页面,整个Web应用会有更统一的风格,会提供更好的整体效果.
SiteMesh通过Filter来截取request和response,然后给原始的页面加入一定的装饰,再把结果返回给客户端.
SiteMesh应用
1. 定义装饰器页面
装饰器页面就是一个普通的JSP页面,但这个页面包含了一些SiteMesh标签,看下面的页面代码:
|
<%@ page contentType="text/html; charset=GBK"%>
<%@ taglib uri="http://www.opensymphony.com/sitemesh/decorator" prefix="decorator"%>
<html>
<head>
<title><decorator:title default="第一个装饰器页面"/></title>
<decorator:head/>
</head>
<body>
SiteMesh<hr>
<decorator:body />
<hr>
<div style="font:9pt" align="center">SiteMesh</div>
</body>
</html> copyright dedecms
|
本文来自织梦
它与传统的JSP页面并没有太大的区别,它包含了三个SiteMesh标签:
1,:将被装饰页面的title部分插入该页面的此处.
2,:将被装饰页面的head部分插入该页面的此处.
3,:将被装饰页面的body部分插入该页面的此处.
2. 配置装饰器页面
下面在配置文件中配置该装饰器页面,配置用WEB-INF\decorators.xml文件,内容如下:
|
<?xml version="1.0" encoding="GBK"?>
<!-- defaultdir指定装饰器文件所在的路径 -->
<decorators defaultdir="/decorators">
<!-- 指定main装饰器,该装饰器使用main.jsp页面 -->
<decorator name="main" page="main.jsp">
<!-- 使用main装饰器装饰所有的JSP页面 -->
<pattern>*</pattern>
</decorator>
</decorators> 织梦好,好织梦
|
dedecms.com
这时访问其它的页面,可以看到所有的页面都被main.jsp装饰过了.







