码迷,mamicode.com
首页 > 其他好文 > 详细

sitemesh技术的应用

时间:2015-07-24 16:19:22      阅读:172      评论:0      收藏:0      [点我收藏+]

标签:

一,基本概念

1,Sitemesh是一种页面装饰技术 :

技术分享 1  :它通过过滤器(filter)来拦截页面访问
技术分享
 2  :根据被访问页面的URL找到合适的装饰模板
技术分享
 3  :提取被访问页面的内容,放到装饰模板中合适的位置
技术分享
 4  :最终将装饰后的页面发送给客户端。技术分享

2,在sitemesh中,页面分为两种:装饰模板和普通页面。
1)装饰模板,是指用于修饰其它页面的页面。
2)普通页面,一般指各种应用页面。
3,接下来,我们通过一个简单的例子来说明一下sitemesh修饰网页的基本原理。

二,模板修饰网页的原理

技术分享

技术分享

技术分享

通过Sitemesh的注册机制,告诉Sitemesh,当访问该路径时使用XXX模板(假定使用前面那个模板)来修饰被访问页面。 

技术分享 

当用户在左边导航栏点击“戏说长城”( /ShowGreatWall.do)时,右边的“戏说长城”页面将会被指定的模板修饰

技术分享

总结上面过程,Sitemesh修饰网页的基本原理,可以通过下面来说明:

技术分享

三,Sitemesh的配置与使用

1)WEB-INF/web.xml中加入filter定义与sitemesh的taglib定义

技术分享     <filter>
技术分享          
<filter-name>sitemesh</filter-name>
技术分享          
<filter-class>com.opensymphony.module.sitemesh.filter.PageFilter</filter-class>
技术分享     
</filter>
技术分享     
<filter-mapping>
技术分享          
<filter-name>sitemesh</filter-name>
技术分享          
<url-pattern>/*</url-pattern>
技术分享     </filter-mapping>
技术分享
技术分享     <taglib>
技术分享          <taglib-uri>sitemesh-decorator</taglib-uri>
技术分享          <taglib-location>/WEB-INF/sitemesh-decorator.tld</taglib-location>
技术分享     </taglib>
技术分享     <taglib>
技术分享          <taglib-uri>sitemesh-page</taglib-uri>
技术分享          <taglib-location>/WEB-INF/sitemesh-page.tld</taglib-location>
技术分享     </taglib> 

2)创建WEB-INF/decorators.xml,在该文件中配置有哪些模板,以及每个模板具体修饰哪些URL,另外也可以配置哪些URL不需要模板控制 , decorators.xml的一个例子如下:

技术分享<excludes>
技术分享
<pattern>/Login*</pattern>
技术分享
</excludes>
技术分享
技术分享
<decorators defaultdir="/decorators">
技术分享    
<decorator name="main" page=“DecoratorMainPage.jsp">
技术分享        
<pattern>/*</pattern> 
技术分享    
</decorator>
技术分享
技术分享    
<decorator name=“pop" page=“PopPage.jsp">
技术分享        
<pattern>/showinfo.jsp*</pattern>
技术分享        
<pattern>
技术分享              /myModule/GreatWallDetailAction.do*
技术分享        
</pattern>
技术分享    
</decorator>
技术分享
</decorators>

3)我们看一个修饰模板的例子

技术分享<%@page contentType="text/html;?charset=GBK"%>
技术分享
<%@taglib uri="sitemesh-decorator"?prefix="decorator" %>
技术分享
技术分享
<html>
技术分享    
<head>
技术分享         
<title<decorator:title/> </title>
技术分享         
<decorator:head/>
技术分享    
</head>
技术分享
技术分享    
<body>
技术分享        Hello World  
<hr/>
技术分享        
<decorator:body/>
技术分享    
</body>
技术分享
</html> 

4)我们看一个被修饰的页面的例子:

技术分享<%@ page contentType="text/html;?charset=GBK"%>
技术分享
<html>
技术分享    
<head>
技术分享        
<title>Hello World</title>
技术分享    
</head>
技术分享
技术分享    
<body>
技术分享        
<p>Decorated page goes here.</p
技术分享    </body
>
技术分享
</html> 

5)我们看一下装饰模板中可以使用的Sitemesh标签 

技术分享<decorator:head />

 取出被装饰页面的head标签中的内容。

技术分享<decorator:body />

取出被装饰页面的body标签中的内容。

技术分享<decorator:title default="技术分享"  />

取出被装饰页面的title标签中的内容。default为默认值

技术分享<decorator:getProperty property="技术分享" default="技术分享"  writeEntireProperty="技术分享"/>

取出被装饰页面相关标签的属性值。

技术分享writeEntireProperty表明,是显示属性的值还是显示“属性=值”

Html标签的属性
Body标签的属性
Meta标签的属性

技术分享注意如果其content值中包含“>或<”会报错,需转码,例如&lt;等等

default是默认值

技术分享<decorator:usePage id="技术分享" />

 将被装饰页面构造为一个对象,可以在装饰页面的JSP中直接引用

6)看一个在装饰模板中使用标签的例子

技术分享<html lang=“ <decorator:getProperty property=‘lang’/> ”>
技术分享    
<head>
技术分享        
<title> <decorator:title default=“你好” /> </title>
技术分享        
<decorator:head />
技术分享    
</head>
技术分享    
技术分享    
<body <decorator:getProperty property=“body.onload" writeEntireProperty=“1"/> >
技术分享         
从meta中获取变量company的名称:
技术分享             <decorator:getProperty property
=“meta.company”/>
技术分享
技术分享            
下面是被修饰页面的body中的内容:
技术分享             <decorator:body 
/>
技术分享
技术分享         
<decorator:usePage id=“myPage" />
技术分享
技术分享         
<%=myPage.getRequest().getAttribute(“username”)%>
技术分享    
</body>
技术分享
</html>

7)看一下相应的在被修饰页面中的代码:

技术分享<html lang=“en”>
技术分享    
<head>
技术分享        
<title>我的sitemesh</title>
技术分享        
<meta name=“company” content=“smartdot”/>
技术分享        
<meta name=“Author” content=“zhangsan”/>
技术分享        
<script>
技术分享             function count(){return 10;}
技术分享        
</script>
技术分享    
</head>
技术分享
技术分享    
<body onload=“count()”>
技术分享         
<p>这是一个被修饰页面</p>
技术分享    
</body>
技术分享
</html>

四,总结

1,Sitemesh最为重要的就是做用于修饰的模板,并在decorators.xml中配置这些模板用于修饰哪些页面。因此使用Sitemesh的主要过程就是:做装饰模板,然后在decorators.xml中配置URL Pattern

2,分析整个工程,看哪些页面需要抽象成模板,例如二级页面、三级页面、弹出窗口等等可能都需要做成相应的模板,一般来说,一个大型的OA系统,模板不会超过8个。

 

— — —— — — — — — — — — — — — — — — — — — — — — —

如果某个特殊的需求请求路径在过滤器的范围内,但又不想使用模板怎么办?
你总不能这么不讲道理吧!
        大家放心吧,SiteMesh早就考虑到这一点了,上面第5步说道的decorators.xml这个时候就起到作用了!
       


下面是我的decorators.xml:

 

<?xml version="1.0" encoding="ISO-8859-1"?> 
<decorators defaultdir="/decorators"> 
    <!-- Any urls that are excluded will never be decorated by Sitemesh --> 
    <excludes> 
        <pattern>/index.jsp*</pattern> 
          <pattern>/login/*</pattern> 
    </excludes> 
    <decorator name="main" page="main.jsp"> 
        <pattern>/*</pattern> 
    </decorator> 
</decorators>

 

decorators.xml有两个主要的结点:
      decorator结点指定了模板的位置和文件名,通过pattern来指定哪些路径引用哪个模板
      excludes结点则指定了哪些路径的请求不使用任何模板

如上面代码,/index.jsp和凡是以/login/开头的请求路径一律不使用模板;

另外还有一点要注意的是:decorators结点的defaultdir属性指定了模板文件存放的目录;


sitemesh技术的应用

标签:

原文地址:http://my.oschina.net/u/2358326/blog/483418

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!