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

 

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值