SiteMesh
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");
});