html 网页装修,HTML装饰器(decorator)

一、背景

最近在看activemq的时候,无意看到其web操作页面的结构框架很有意思,刚开始有点懵,但仔细摸索半天并结合度娘的力量,发现它是使用了 sitemesh应用Decorator模式,在进行了入门学习和几个小例子的实践之后,我趁热写了此文,以便下次回顾的时候可以复看一下

二、介绍

Sitemesh是由一个基于Web页面布局、装饰Decorator及与现存Web应用整合的框架。它能帮助我们在由大量页面工程的项目中创建一致的页面布局和外观,如一致的导航条、一致的banner、一致的版权等。它不仅能处理动态的内容,如JSP、PHP、ASP、CGI等产生的内容,还能处理静态的内容,比如HTML的内容,使得它的内容也符合你的页面结构的要求。甚至它能像include那样将HTML文件作为一个面板的形式嵌入到别的文件中去。所有的这些,都是GOF的Decorator模式的最生动的实现。装饰模式是在不必改变原类文件和使用集成的情况下,动态地扩展一个对象的功能。它能通过创建一个包装对象,也就是装饰来包裹的对象。尽管它是由Java语言来实现的,但是它能与其他Web应用很好的集成

三、原理

SiteMesh是基于Servlet的filter的,即过滤流。它是通过截取response,并进行装饰后再交付给客户。

其中涉及到两个名词: 装饰页面(decorator page)和 "被装饰页面(Content page)" , 即 SiteMesh通过对Content Page的装饰,最终得到页面布局和外观一致的页面,并返回给客户

sitemesh运行环境需要:servlet, JDK 。

四、使用

3.1、decorator的实现(参照activemq的文件结构与配置,看的懵的可以去对着activemq看)

https://github.com/sitemesh/sitemesh3下载我们需要的jar包:sitemesh-3.0.1.jar

a、在我们的web.xml中配置如下信息:

sitemesh

com.opensymphony.module.sitemesh.filter.PageFilter

sitemesh

/*

配置这个过滤器,对所有的请求进行过滤

b、 在WEB-INF目录下新建一个decorators.xml文件(/decorator是你的包装jsp根路径,此处即为目录:webapps/应用

名/decorators,下面定义的main.jsp,panel.jsp,printable.jsp都是放在该目录下的)

/xml/*

/slave.jsp

/index2.jsp

/*

定义装饰页面,/*定义该装饰页面匹配的路径,/*代表匹配所有的页面

定义不需要拦截的地址

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值