SiteMesh3配置

SiteMesh3 支持两种主要的配置: XML 和 Java,甚至两者可以共用。

 

XML Java
  • 容易上手
  • 配置更改时可以自动重载
  • 不需要懂得java编程 
  • 更灵活的制定 
  • 不需要多余的配置文件
  • 可以使用JRuby, Groovy, Scala等语言配置

 

 

 

基于xml的配置

配置文件需放置于/WEB-INF/sitemesh3.xml ,如


  
  

 

 

 

基于java的配置

必须编写一个过滤器,继承org.sitemesh.config.ConfigurableSiteMeshFilter 且重载applyCustomConfiguration方法,如

public class MySiteMeshFilter extends ConfigurableSiteMeshFilter {
  @Override
  protected void applyCustomConfiguration(SiteMeshFilterBuilder builder) {
    builder.addDecoratorPath("/*", "/decorator.html")
           .addDecoratorPath("/admin/*", "/admin/decorator.html");
  }
}

 

 

如果xml和java两个配置方法共用,sitemesh3在调用applyCustomConfiguration()方法前会先加载xml的配置。

 

 

配置渲染

  • 给所有路径配置一个默认的渲染
  • 给特殊的路径配置一个渲染
  • 给某个路径配置多个渲染,一个渲染依赖于前面的渲染
  • 排除某个路径

xml



  
  

  
  
  

  
  
    /articles/*
    /decorators/article.html
    /decorators/two-page-layout.html
    /decorators/common.html
  

  
  
  


 java

public class MySiteMeshFilter extends ConfigurableSiteMeshFilter {
  @Override
  protected void applyCustomConfiguration(SiteMeshFilterBuilder builder) {
            // 配置默认的渲染器. 将应用于所有路径.
    builder.addDecoratorPath("/*", "/default-decorator.html")
           // 配置特定路径的渲染器.
           .addDecoratorPath("/admin/*", "/another-decorator.html")
           .addDecoratorPath("/*.special.jsp", "/special-decorator.html")
           // 配置多个渲染器.
           .addDecoratorPaths("/articles/*", "/decorators/article.html", 
                                             "/decoratos/two-page-layout.html", 
                                             "/decorators/common.html")
           // 不被渲染的路径.
           .addExcludedPath("/javadoc/*")
           .addExcludedPath("/brochures/*");
  }
}

 

对于大多数情况,上面的配置就足够使用了。还有更高级的应用,如配置MIME类型,在页面里嵌入tag标签等。

你可能感兴趣的:(SiteMesh3)