sitebricks 的 decoration是类似于apache tapestry 的layout布局这样的一个“brick”。
关于decoration的具体用法,在sitebricks的主页上有一个示例:http://sitebricks.org/#decoration
用法并不复杂,概括起来,主要有以下几个关键点是需要注意的:
1、建立模板class和html,比如:Decorator.html & Decorator.class,模板类必须为抽象类。
@Show("Decorator.html") abstract class Decorator { }
2、在模板上设置页面标题,便于通过页面标题区分不同的页面:
<html> <head> <title>${pageTitle}</title> </head> <body> <span>固定显示的内容。</span> @Decorated <div>不同页面将显示的内容。</div> </body> </html>
那么在Decorator.class中增加一行代码:
@Show("Decorator.html") abstract class Decorator { public abstract String getPageTitle(); }
3、页面类必须使用@Decorated的annotation,并且继承Decorator.class,实现getPageTitle()。
@Decorated public class Home extends Decorator { @Override public String getPageTitle() { return "Home Page"; } }
目前需要解决的问题:
1、当前页的menu block显示特定的css class:即要在Decorator.class中判断是否为当前页,并给Decorator.html中的页面导航菜单加上特定的css class,比如:acitve。
<nav id="menu"> <ul> <li class="active"> <a href="/">Home</a> </li> <li> <a href="/flow">Flow</a> </li> <li> <a href="http://google-sitebricks.googlecode.com/svn/trunk">source</a> </li> <li> <a href="http://code.google.com/p/google-guice">guice</a> </li> </ul> </nav>
2、在Decorator.class中获取页面名称,比如Home.class的页面名称“Home”。或许可以通过@Decorated的annotation来获取页面类并取得该类的名称?