SiteMesh

优质
小牛编辑
129浏览
2023-12-01

Overview

Ruby on Rails 一直有这种Web-page layout and decoration framework,用户只要定义页面核心的内容,框架会自动加上页头页脚,左边栏,右边栏之类的内容,在上述内容修改时无需批量修改页面。

它的实现原理,无非是用一个Filter读取页面准备输出的内容,然后分析页面内容,将title,header, body插入到模板里再重新输出。听到这里,是不是忍不住想到性能一定不咋样?然后想想,和传统的在页面里include header.jsp 有什么区别?

区别就是一个由页面自己控制include的内容,一个由框架控制include内容和layout。后者在layout方面的灵活性更大,Eclipse里的内容页面也不会因为找不到要include的jsp而出红叉叉。

SiteMesh3

SiteMesh3只有Alpha2版本而且很久没更新了,和SpringMVC配合,有些静态内容会出现NO Content的错误。 虽然它号称性能快3倍内存少1倍,但还是保险起见依然用SiteMesh2了。

另外,Atlassian公司因为在自己的产品中使用了SiteMesh2,所以后来也一直有维护,出到了2.5-atlassian-9版,不过不在maven中央库中,可以在[这里下载|https://maven-us.nuxeo.org/nexus/content/groups/public/opensymphony/sitemesh/2.5-atlassian-9/]。

SiteMesh2使用

Apache Tiles目前的配置还是则么繁琐,貌似每个目录下都需要一个配置文件,而SiteMesh则实现了简洁的集中配置。

Step by Step的例子在这里 https://github.com/sitemesh/sitemesh2

理论上SiteMesh只会搞那些MIME type为html的页面,但在配置里先exclude掉一些静态内容和Restful API的路径会更省心

SpringSide中decorators.xml的配置:

<?xml version="1.0" encoding="UTF-8"?>
<decorators defaultdir="/WEB-INF/layouts/">
    <excludes>
        <pattern>/static/*</pattern>
                <pattern>/api/*</pattern>
    </excludes>

    <decorator name="default" page="default.jsp">
        <pattern>/*</pattern>
    </decorator>
</decorators>

Menu的高亮

因为Menu现在是在外部渲染了,不容易传参数给它表明哪个tab是当前tab应该被高亮。springside里的做法是在页面里,通过javascript去设置class,见showcase里的页面。

        $(document).ready(function() {
            $("#account-tab").addClass("active");
        });