运用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/
),里面有丰富的文档和帮助