Skip to content

SiteMesh

Calvin edited this page Nov 13, 2013 · 14 revisions

##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#readme

理论上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");
		});