一、SiteMesh项目简介

OS(OpenSymphony)的SiteMesh是一个用来在JSP中实现页面布局和装饰(layout and decoration)
的框架组件,能够帮助网站开发人员较容易实现页面中动态内容和静态装饰外观的分离。

Sitemesh是由一个基于Web页面布局、装饰以及与现存Web应用整合的框架。它能帮助我们在由大
量页面构成的项目中创建一致的页面布局和外观,如一致的导航条,一致的banner,一致的版权,等等。
它不仅仅能处理动态的内容,如jsp,php,asp等产生的内容,它也能处理静态的内容,如htm的内容,
使得它的内容也符合你的页面结构的要求。甚至于它能将HTML文件象include那样将该文件作为一个面板
的形式嵌入到别的文件中去。所有的这些,都是GOF的Decorator模式的最生动的实现。尽管它是由java语言来实现的,但它能与其他Web应用很好地集成。

官方:http://www.opensymphony.com/sitemesh/

下载地址:http://www.opensymphony.com/sitemesh/download.action 目前的最新版本是Version 2.3

二、为什么要使用SiteMesh?

我们的团队开发J2EE应用的时候,经常会碰到一个比较头疼的问题:

由于Web页面是由不同的人所开发,所以开发出来的界面通常是千奇百怪,通常让项目管理人员苦笑不得。

而实际上,任何一个项目都会要求界面的统一风格和美观,既然风格统一,那就说明UI层肯定有很多可以抽出来
共用的静态或动态部分;如何整合这些通用的静态或动态UI呢?Apache Tiles框架站了出来很好的解决了这一问题,
再加上他与struts的完美集成,导致大小项目都把他作为UI层的首选框架,

但是

Tiles确实有着它很多的不足之处,下文我会介绍,本文想说的是,除了Apache Tiles框架,其实我们还有更好的解
决方案,那就是:SiteMesh;

本文
   
   介绍了一个基于Web页面的布局、装饰以及应用整合的框架Sitemesh,它能帮助你为你的应用创建一致的外观,
很好的取代Apache Tiles;

三、SiteMesh VS Apache Tiles

用过struts的朋友应该对Apache Tiles的不会陌生,我曾经有一篇文章介绍过struts中tiles框架的组合与继承,
现在怎么看怎么觉得复杂;
      
      从使用角度来看,Tiles似乎是Sitemesh标签<page:applyDecorator>的一个翻版。其实sitemesh最强的
一个特性是sitemesh将decorator模式用在过滤器上。任何需要被装饰的页面都不知道它要被谁装饰,所以它就
可以用来装璜来自php、asp、CGI等产生的页面了。你可以定义若干个装饰器,根据参数动态地选择装饰器,
产生动态的外观以满足你的需求。它也有一套功能强大的属性体系,它能帮助你构建功能强大而灵活的装饰器。
相比较而言,在这方面Tiles就逊色许多。

个人觉得在团队开发里面,Apache Tiles框架会导致所有人不仅仅要了解并且清楚Apache Tiles的存在,
并且要特别熟悉每一个Tiles layout模板的作用,否则就可能出现用错模板的情况;除此之外,每个人涉及到
的所有WEB页面都需要去配置文件里面逐个配置,不仅麻烦出错的几率还高;
      而以上所有的不足都是SiteMesh所不存在的;

四、SiteMesh的基本原理

      一个请求到服务器后,如果该请求需要sitemesh装饰,服务器先解释被请求的资源,然后根据配置文件
获得用于该请求的装饰器,最后用装饰器装饰被请求资源,将结果一同返回给客户端浏览器。

五、如何使用SiteMesh

这里以struts2+spring2+hibernate3构架的系统为例
     1、下载SiteMesh 
         下载地址:http://www.opensymphony.com/sitemesh/download.action 目前的最新版本是Version 2.3
      
       2、在工程中引入SiteMesh的必要jar包,和struts2-sitemesh-plugin-2.0.8.jar;
      
      3、修改你的web.xml,在里面加入sitemesh的过滤器,示例代码如下:

<!--sitemesh配置 -->
    <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>

注意过滤器的位置:应该在struts2的org.apache.struts2.dispatcher.FilterDispatcher过滤器之前org.apache.struts2.dispatcher.ActionContextCleanUp过滤器之后,否则会有问题;

4、在下载的SiteMesh包中找到sitemesh.xml,(\sitemesh-2.3\src\example-webapp\WEB-INF目录下就有)

将其拷贝到/WEB-INF目录下;

5、在sitemesh.xml文件中有一个property结点(如下),该结点指定了decorators.xml在工程中的位置,让sitemesh.xml能找到他;
按照此路径新建decorators.xml文件,当然这个路径你可以任意改变,只要property结点的value值与其匹配就行;


<property name="decorators-file"value="/WEB-INF/sitemesh/decorators.xml"/>

6、在WebRoot目录下新建decorators目录,并在该目录下新建一个模板jsp,根据具体项目风格编辑该模板,
如下示例:我的模板:main.jsp

<%@ page language="java"pageEncoding="UTF-8"%>
<%@taglib prefix="decorator"
    uri="http://www.opensymphony.com/sitemesh/decorator"%>
<%@taglib prefix="page"uri="http://www.opensymphony.com/sitemesh/page"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<%
    response.setHeader("Pragma", "no-cache");
    response.setHeader("Cache-Control", "no-cache");
    response.setDateHeader("Expires", 0);
%>
<html>
    <head>
        <title><decorator:title default="kangxm test"/>
        </title>
        <!--页面Head由引用模板的子页面来替换 -->
        <decorator:head />
    </head>
    <body id="page-home">
        <div id="page-total">
            <div id="page-header">
                <table width="100%"border="0"cellspacing="0"cellpadding="0">
                    <tr>
                        <td>
                            <div class="topFunc">
                                我的账户
                                |
                                退出
                            </div>
                        </td>
                    </tr>
                </table>
            </div>
        </div>
        <!--end header -->
        <!--Menu Tag begin -->
        <div id="page-menu"style="margin-top: 8px; margin-bottom: 8px;">
            <div>
                这里放菜单
            </div>
        </div>
        <!--Menu Tag end -->
        <div id="page-content"class="clearfix">
            <center>
                <table width="100%"border="0"cellpadding="0"cellspacing="0">
                    <tr>
                        <td>
                            <decorator:body /><!--这里的内容由引用模板的子页面来替换 -->
                        </td>
                    </tr>
                </table>
            </center>
        </div>
        <!--end content -->
        <div id="page-footer"class="clearfix">

这里放页面底部
            <!--end footer -->
        </div>
        <!--end page -->
    </body>
</html>

这就是个简单的模板,页面的头和脚都由模板里的静态HTML决定了,主页面区域用的是<decorator:body />标签;
也就是说凡是能进入过滤器的请求生成的页面都会默认加上模板上的头和脚,然后页面自身的内容将自动放到<decorator:body />标签所在位置;

<decorator:title default="Welcome to test sitemesh!" />:读取被装饰页面的标题,并给出了默认标题。
<decorator:head />:读取被装饰页面的<head>中的内容;
<decorator:body />:读取被装饰页面的<body>中的内容;

7、说到这里大家就要想了,那如果某个特殊的需求请求路径在过滤器的范围内,但又不想使用模板怎么办?
你总不能这么不讲道理吧!
        大家放心吧,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的项目,跟以前用tiles框架相比,最大的感受就是简单,系统设计阶段
就把模板文件和sitemesh框架搭好了!哪些页面使用框架哪些不使用,全部都通过UI Demo很快就定义出来了;
在接下来的开发中所有成员几乎感受不到sitemesh的存在,各自仅仅关心自己的模块功能实现;

七、总结

使用sitemesh给我们带来的是不仅仅是页面结构问题,它的出现让我们有更多的时间去关注底层业务
逻辑,而不是整个页面的风格和结构。它让我们摆脱了大量用include方式复用页面尴尬局面,也避免了tiles
框架在团队开发中的复杂度,它还提供了很大的灵活性以及给我们提供了整合异构Web系统页面的一种方案。

转载于:https://www.cnblogs.com/felixjia/p/3496558.html

SiteMesh:一个优于Apache Tiles的Web页面布局、装饰框架相关推荐

  1. 前端的小玩意(9.5)——做一个仿360工具箱的web页面(完结篇,可以跑起来的工具箱)

    前端的小玩意(9.1)--做一个仿360工具箱的web页面(Tab按钮切换) http://blog.csdn.net/qq20004604/article/details/52216203 前端的小 ...

  2. 前端的小玩意(9.3)——做一个仿360工具箱的web页面(我的工具里的模板和样式)

    前端的小玩意(9.1)--做一个仿360工具箱的web页面(Tab按钮切换) http://blog.csdn.net/qq20004604/article/details/52216203 前端的小 ...

  3. php播放一个提示音,ajax实现web页面的消息实时提醒时播放提示音

    在应用系统的开发过程中,经常要使用到新消息的提醒功能,比如说后台有一个告警消息,web页面就会实时的收到这个告警的消息,且发出提示音. 这其实就是涉及到两个方面的知识,一个是http实时消息的推送,在 ...

  4. Web页面布局方式小结

    Web页面是由块元素组成的,正常情况下块元素一个个按垂直方向排布,构成了页面.可是这样的主要的布局方式绝大多时候不能满足我们的需求,所以各种布局方式应运而生,本文就对这些布局方式做个小结. 1.元素漂 ...

  5. 后台管理页面布局、web页面布局

    做一个简单的页面布局 演示地址:https://genin.gitee.io/web-demo/web-layout.html 基本结构如下 <body> <!-- svg图标 -- ...

  6. 仿淘宝菜单分类页面布局--iframe框架有限替代方案

    之前做一些类似后台管理界面,典型的左侧菜单.右侧布局,基本都采用iframe框架来完成 虽然iframe操作起来非常方便,但是也存在问题,例如页面不够美观,css样式布局会出现各种复杂问题以至于显得比 ...

  7. 前端的小玩意(9.1)——做一个仿360工具箱的web页面(Tab按钮切换)

    需求: ①写一个web版的360工具箱,示意图如下: ②无左上返回按钮,右上按钮有皮肤切换,下拉框(但无点击逻辑): ③按钮点击有事件,但事件是console.log(按钮名): ④可以在全部工具和我 ...

  8. 前端的小玩意(9.2)——做一个仿360工具箱的web页面(全部工具里面的模板)

    上一篇链接: http://blog.csdn.net/qq20004604/article/details/52216203 DEMO: http://jianwangsan.cn/toolbox ...

  9. Web页面布局上的幽灵事件 -- 外边距合并折叠解惑

    最初的想法是准备写BFC的设计方面的一些考虑,当然这只是从一个使用者角度来理解的设计 虽然会跟实际有一定差距,但对于能更好的来理解记忆BFC还是有用处的. 现在确定了要写的东西跟最初有些不同,但是很典 ...

最新文章

  1. 爱奇艺火爆的背后,个性化推荐排序是如何配合的?
  2. Javascript面向对象编程(一):封装
  3. 看不到这些痛点,就无法入局智能制造
  4. 第二篇:Dapper中的一些复杂操作和inner join应该注意的坑
  5. react学习(59)--this.props语法糖
  6. 剪映电脑版_七款手机剪辑app,效果堪比电脑软件
  7. python读取mysql中表内数据转换成json_使用python将mySql查询结果转换为json
  8. PHP实现调用淘宝SDK开放接口返回天猫或淘宝商品详情
  9. Java 时断时续之————Java事件
  10. java logfaction_Java8 下 重构log
  11. sklearn 特征选择与特征抽取 —— feature_selection、feature_extraction
  12. 基于阿里云服务器+wordpress构建自己的网站(全过程系列,无需任何编程知识)
  13. 欢迎来到德莱联盟(一)
  14. C#实现10进制转2进制
  15. [android界面]android中src和background区别——前景与背景
  16. 深入浅出 NXLog (二)
  17. visio绘制流程图连接线总拐弯
  18. 大型门户网站架构分析
  19. 动量梯度下降法 Momentum
  20. 如何在手机浏览器中打开安卓APP

热门文章

  1. 总结Movies MVC3教程示例的知识点
  2. HDFS HA介绍及配置理解
  3. MapReduce基础开发之十一DistributedCache使用
  4. (转载)Linux OOM Killer个人总结
  5. 2009-08-19股市大跌分析(转载)
  6. windows 7硬盘安装Ubuntu 12.04 后出现grub,无法进入系统解决办法
  7. 父类卡子类卡java_Java中关于子类覆盖父类的抛出异常问题
  8. 网页去重||SimHash(高效的文本相似度去重算法)——适合大批量文档的相似度计算
  9. windows 技术篇 - uispy 工具获取和使用,windows窗口属性快捷查看工具
  10. PyQt5 技术篇-QComboBox下拉框绑定监听事件实例演示