sitemesh建立复合视图(2)

原创 2007年09月29日 04:52:00
简介:

sitemesh应用Decorator模式,用filter截取request和response,把页面组件head,content,banner结合为一个完整的视图。
通常我们都是用include标签在每个jsp页面中来不断的包含各种header, stylesheet, scripts and footer,现在,
在sitemesh的帮助下,我们可以开心的删掉他们了。如下图,你想轻松的达到复合视图模式,那末看完本文吧。

 

hello sitemesh:
  1. 在WEB-INF/web.xml中copy以下filter的定义:
    <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. copy所需jar和dtd文件至相应目录,访问opensymphony.sourceforge.net的cvs以获取sitemesh最新版本。
    sitemesh.jar WEB-INF/lib
    sitemesh-decorator.tld WEB-INF
    sitemesh-page.tld WEB-INF
  3. 建立WEB-INF/decorators.xml描述各装饰器页面(可仿照sitemesh例子)。
    <decorators defaultdir="/_decorators">     
    <decorator name="main" page="main.jsp">
    <pattern>*</pattern> </decorator>
    </decorators>

     

  4. 建立装饰器页面 /_decorators/main.jsp
    <%@ page contentType="text/html; charset=GBK"%> 
    <%@ taglib uri="sitemesh-decorator" prefix="decorator" %>
    <html>
    <head> <title><decorator:title default="装饰器页面..." /></title>
    <decorator:head />
    </head>
    <body> sitemesh的例子<hr>
    <decorator:body />
    <hr>chen56@msn.com </body>
    </html>

     

  5. 建立一个的被装饰页面 /index.jsp(内容页面)
    <%@ page contentType="text/html; charset=GBK"%> 
    <html>
    <head> <title>Agent Test</title>
    </head>
    <body> <p>本页只有一句,就是本句.</p>
    </body>
    </html>

最后访问index.jsp,将生成如下页面:

而且,所有的页面也会如同index.jsp一样,被sitemesh的filter使用装饰模式修改成如上图般模样,却不用再使用include标签

 

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

使用sitemesh建立复合视图

sitemesh是opensymphony团队开发的j2ee应用框架之一,旨在提高页面的可维护性和复用性。opensymphony的另一个广为人知的框架为webwork是用作web层的表示框架。他们都...

使用sitemesh建立复合视图

sitemesh是opensymphony团队开发的j2ee应用框架之一,旨在提高页面的可维护性和复用性。opensymphony的另一个广为人知的框架为webwork是用作web层的表示框架。他们都...

sitemesh decorators 复合页面Demo

1、下载sitemesh-2.4.2.jar添加到classpath里面。 2、web.xml  文件中添加filter sitemesh com.opensymphony.modu...

ofbiz之entity 实体解析 扩展 视图 复合列写法

ofbiz之entity实体解析 扩展 视图 复合列写法

Apache Tiles 学习(一)、复合视图模式

Apache Tiles 是什么? A free open-sourced templating framework for modern Java applications. Based upo...

struts2之整合sitemesh(定义装饰器页面)

struts2之整合sitemesh(定义装饰器页面)
  • fhd001
  • fhd001
  • 2011-04-06 17:26
  • 1169

[Struts 2] decorator(sitemesh)修饰器的配置和使用

在struts2项目的基础上,配置sitemesh
  • gopain
  • gopain
  • 2014-11-06 14:40
  • 1703

Struts2 使用SiteMesh做网页布局

Struts2 使用SiteMesh做网页布局 简单来讲SiteMesh就是用来做网页母版 Layout分层的。   SiteMesh官方网站给出的最新版本是SiteMesh Ver...

Struts2+sitemesh下搭建jsTree1.0的示例

jsTree是一款强大的构建树状菜单的jQuery插件,项目中使用它做了树状菜单的复选框,自己研究了一下,做了个示例在此记录。先从官网(http://plugins.jquery.com/projec...

Struts2 使用SiteMesh做网页布局

简单来讲SiteMesh就是用来做网页母版 Layout分层的。   SiteMesh官方网站给出的最新版本是SiteMesh Version 2.4.1,但是下载不下来!!下载页面NOT...
  • zavens
  • zavens
  • 2012-09-03 22:58
  • 3594
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)