使用Beetl Layout标签

    Beetl  (http://beetl.sourceforge.net/ )   是下一代模板语言,里面有很多新特性,其中有标签语法。可以完成很多功能,如inlcude其他模板,页面布局,以及cache等功能,有点类似jsp的 标签。

    标签语法如下:

    标签名参数1参数2 ......) {
   
    标签体

     }

    如通常首页里用的include标签,在模板里就是这么用的:

  <!--: includeFileTemplate("/header.html") {-->

  Hello,Javamonkey, 上次登录时间是03-18

  <!--:}-->

   includeFileTemplate是beetl 内置的标签函数,允许多个参数,第一个参数必须是一个模板路径。在beetl渲染此页面的时候,将会渲染参数一指定的模板,如header.html. 至于标签体的内容,将忽略。

   在这儿,header.html内容如下

Hello,${name},你上次登录时间是${lastLoginDate,dateformat='MM-dd'}
 


  
   不同于其他模板引擎或者jsp的include功能,includeFileTemplate还允许有标签体(尽管输出的时候忽略),这样,降低模板语言对原有文件的侵入性。

   Beetl提供的另外一个内置标签是layout标签(在此感谢网友“原上一棵草”的建议)。
   通常页面都有一个布局,大体上有页面头部,尾部,以及正文三部分。头部和尾部内容基本上固定,只有正文是变化的。一种处理方式是采用如上inlcudeFileTemplate,如下

<!--: includeFileTemplate("/header.html'){}-->
<table>
这是正文
</table>
<!--: includeFileTemplate("/footer.html'){}-->
 

 
  但考虑到布局有可能需要换,更好的方式是使用layout标签。如下

<!--: layout("/layout.html'){-->
<table>
这是正文
</table>
<!--:} -->

  layout标签允许指定一个layout模板文件,在渲染页面的时候,会将layout标签体的渲染内容作为一个layoutContent变量插入到layout指定模板文件里,如下是本例子中layout.html

<div id="header" >....... </div>

${layoutContent}

<div id = "footer">.........</div>
 

    因此采用layou标签会极大提供页面布局的灵活性,而不需要再使用诸如titles这样额外布局开源框架

   总之,beetl标签机制提供了很多强大功能,很容易实现其他模板引擎难以实现的功能,你也很容像自定义jsp simleTag那样,自己定义标签,如memcachedTag,一个将内容缓存到memecached的标签等等。如果想了解更多关于beetl及其标签的概念,可以访问(http://beetl.sourceforge.net/ ),里面有丰富的文档和帮助

猜你喜欢

转载自javamonkey.iteye.com/blog/1457996