- Introduction
- Quick Start
- Design
- Tutorial
- Spring MVC
- JSP/JSTL/Servlet
- JQuery and plugins
- Ajax
- Twitter Bootstrap CSS
- SiteMesh
- YUICompressor
- Spring Restful Service
- JAX-WS/CXF
- Spring Data JPA
- JPA/Hibernate
- MyBatis
- Database
- H2 Database
- Datasource
- Transaction
- Redis
- Cache Overview
- Guava Cache
- Ehcache
- Memcached
- Shiro Security
- Crypto
- Schedule/Quartz
- Jmx
- System Protection
- Hystrix
- Rate Limiter
- Monitoring and Metrics
- Metrics-library
- Graphite
- Logging/Slf4j/Logback
- Logstash
- Spring
- Validation Overview
- JQuery Validation
- Hibernate Validator
- General Utilizes
- JSON/JAXB
- Date
- Test Overview
- Unit Test/Mockito/AssertJ
- Selenium2
- BDD
- Performace-test
- JMeter
- Profiler
- Simulator Overview
- Nodejs
- Eclipse
- Maven
- Sonar
- git
- Travis CI
- Jetty
- Micro-Service Architecture/Executable War
- AssertJ
- CreateNewProject
- Dozer
- Graphite-Windows
- Hello-Everybody
- Jaxb
- Json
- Mock
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");
});
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论