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