页面装饰技术—SiteMesh

2023-12-13 17:32
文章标签 技术 页面 装饰 sitemesh

本文主要是介绍页面装饰技术—SiteMesh,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一,基本概念
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://www.chinasem.cn/article/489315

相关文章

Python结合Free Spire.PDF for Python实现PDF页面旋转

《Python结合FreeSpire.PDFforPython实现PDF页面旋转》在日常办公或文档处理中,我们经常会遇到PDF页面方向错误的问题,本文将分享如何用Python结合FreeSpir... 目录基础实现:单页PDF精准旋转完整代码代码解析进阶操作:覆盖多场景旋转需求1. 旋转指定角度(90/27

使用Python实现在PDF中添加、导入、复制、移动与删除页面

《使用Python实现在PDF中添加、导入、复制、移动与删除页面》在日常办公和自动化任务中,我们经常需要对PDF文件进行页面级的编辑,使用Python,你可以轻松实现这些操作,而无需依赖AdobeAc... 目录1. 向 PDF 添加空白页2. 从另一个 PDF 导入页面3. 删除 PDF 中的页面4. 在

python协程实现高并发的技术详解

《python协程实现高并发的技术详解》协程是实现高并发的一种非常高效的方式,特别适合处理大量I/O操作的场景,本文我们将简单介绍python协程实现高并发的相关方法,需要的小伙伴可以了解下... 目录核心概念与简单示例高并发实践:网络请求协程如何实现高并发:核心技术协作式多任务与事件循环非阻塞I/O与连接

JavaScript装饰器从基础到实战教程

《JavaScript装饰器从基础到实战教程》装饰器是js中一种声明式语法特性,用于在不修改原始代码的情况下,动态扩展类、方法、属性或参数的行为,本文将从基础概念入手,逐步讲解装饰器的类型、用法、进阶... 目录一、装饰器基础概念1.1 什么是装饰器?1.2 装饰器的语法1.3 装饰器的执行时机二、装饰器的

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

C#自动化实现检测并删除PDF文件中的空白页面

《C#自动化实现检测并删除PDF文件中的空白页面》PDF文档在日常工作和生活中扮演着重要的角色,本文将深入探讨如何使用C#编程语言,结合强大的PDF处理库,自动化地检测并删除PDF文件中的空白页面,感... 目录理解PDF空白页的定义与挑战引入Spire.PDF for .NET库核心实现:检测并删除空白页

Java中的Schema校验技术与实践示例详解

《Java中的Schema校验技术与实践示例详解》本主题详细介绍了在Java环境下进行XMLSchema和JSONSchema校验的方法,包括使用JAXP、JAXB以及专门的JSON校验库等技术,本文... 目录1. XML和jsON的Schema校验概念1.1 XML和JSON校验的必要性1.2 Sche

Python中高级文本模式匹配与查找技术指南

《Python中高级文本模式匹配与查找技术指南》文本处理是编程世界的永恒主题,而模式匹配则是文本处理的基石,本文将深度剖析PythonCookbook中的核心匹配技术,并结合实际工程案例展示其应用,希... 目录引言一、基础工具:字符串方法与序列匹配二、正则表达式:模式匹配的瑞士军刀2.1 re模块核心AP

springboot自定义注解RateLimiter限流注解技术文档详解

《springboot自定义注解RateLimiter限流注解技术文档详解》文章介绍了限流技术的概念、作用及实现方式,通过SpringAOP拦截方法、缓存存储计数器,结合注解、枚举、异常类等核心组件,... 目录什么是限流系统架构核心组件详解1. 限流注解 (@RateLimiter)2. 限流类型枚举 (

Python实现PDF按页分割的技术指南

《Python实现PDF按页分割的技术指南》PDF文件处理是日常工作中的常见需求,特别是当我们需要将大型PDF文档拆分为多个部分时,下面我们就来看看如何使用Python创建一个灵活的PDF分割工具吧... 目录需求分析技术方案工具选择安装依赖完整代码实现使用说明基本用法示例命令输出示例技术亮点实际应用场景扩