jetbrick-template-1.x 旧版文档请看这里:http://subchen.github.io/jetbrick-template/1x/

§布局 layout

通常页面都有一个布局,大体上有页面头部,尾部,以及正文三部分。头部和尾部内容基本上固定,只有正文是变化的。

jetbrick-template 可以使用多种方法实现模板的 layout 功能。主要涉及到下面的几个指令和标签。

§1. 常规模式

我们将页面公共部分放在 include 文件中,然后在每个页面中应用 include 文件来实现内容共享。

main.jetx

#include("/include/header.jetx")
<table>  
  这是正文内容  
</table>  
#include("/include/footer.jetx")

这个不算 layout? 呵呵,继续放下看。

§2. 变种模式

常规模式中,只是共享了一些公共内容,但是并没有实现真正的 layout,因为 layout 一变,include 的方式可能就会发生变化,这样所有文件都要重新 include,不是很方便。

下面就是 #include 模式的变种(动态 include),来实现真正的 layout。

模板 layout.jetx

<html>
  <head>
    <title>${title}</title>
  </head>
  <body>
    <div class="header">This is a logo image.</div>

    #include(param.url)

    <div class="footer">Copyright @2000-2010, All Rights Reserved.</div>
  </body>
</html>

main.jetx

<table>  
  这是正文内容  
</table>

Action.java

String url = "/layout.jetx?url=" + URLEncoder.encode("/main.jetx", "utf-8);
RequestDispatcher rd = getServletContext().getRequestDispatcher(url);
rd.forward(request, response);

怎么样?通过一个 url 参数来达到动态 layout 的目的,这样我们以后只要修改layout.jetx 文件就能达到修改所有页面布局了。

URL 访问方法: http://127.0.0.1:8080/layout.jetx?url=main.jetx

§3. 主动 Layout

上面的 #include 还只能算是被动的 layout,而要实现真正主动的 layout,我们还必须请出我们强大的自定义标签 #tag layout_block()

模板 layout.jetx

<html>
  <head>
    <title>${title}</title>
  </head>
  <body>
    <div class="header">
        This is a header.
    </div>
    <div>
        ${bodyContent1}
    </div>
    <div>
        ${bodyContent2}
    </div>
    <div class="footer">
        This is a footer.
    </div>
  </body>
</html>

main.jetx

#set(String title = "TITLE")

#tag layout_block("bodyContent1")
    BODY 1111
#end

#tag layout_block("bodyContent2")
    BODY 2222
#end

#include ("/layout.jetx")

输出结果

<html>
  <head>
    <title>TITLE</title>
  </head>
  <body>
    <div class="header">
        This is a header.
    </div>
    <div>
        BODY 1111
    </div>
    <div>
        BODY 2222
    </div>
    <div class="footer">
        This is a footer.
    </div>
  </body>
</html>

怎么样?现在就可以随意的进行组合了。

§4. layout_block 的默认值和重载

layout.jetx 中,我们也可以定义默认内容,在 main.jetx 中对默认内容进行重载,如下:

模板 layout.jetx

<html>
  <head>
    <title>${title}</title>
  </head>
  <body>
    <div class="header">
        This is a header.
    </div>
    <div>
        #tag layout_block_default("bodyContent1")
            We are default 111
        #end
    </div>
    <div>
        #tag layout_block_default("bodyContent2")
            We are default 222
        #end
    </div>
    <div class="footer">
        This is a footer.
    </div>
  </body>
</html>

main.jetx

#set(String title = "TITLE")

#tag layout_block("bodyContent1")
    BODY 1111
#end

#include ("/layout.jetx")

输出结果

<html>
  <head>
    <title>TITLE</title>
  </head>
  <body>
    <div class="header">
        This is a header.
    </div>
    <div>
        BODY 1111
    </div>
    <div>
        We are default 222
    </div>
    <div class="footer">
        This is a footer.
    </div>
  </body>
</html>

§5. 总结

不管采用哪种方式,jetbrick-template 都提供很大的灵活性来实现页面布局功能。

其中自定义 #tag 标签机制提供了非常强大功能,很容易实现其他模板引擎难以实现的功能,比如像 JSP Taglib 一样实现自定义标签,如 Cache Tag 将内容缓存到 memecached / redis 的标签等等。