扩展Beetl标签,支持父子嵌套和脚本绑定

工程例子在  https://git.oschina.net/xiandafu/beetl-json


安装

TAG.htmltag= com.beetl.tagext.HTMLTag
TAG.htmltagvar= com.beetl.tagext.HTMLVarBindingTag

例子

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>复杂的标签实现演示</title>
</head>
<body>

<p> 简单例子 <p>
<#simple>hello</#simple>

<p> 绑定例子 <p>
<#data var="name,index">
name=${name},index=${index}.
</#data>


<p>标签嵌套例子</p>
<%
var data = [{id:1,name:'你好'},{id:2,name:'他好'}];
%>
<#table data="${data}" var="row">
<#tr name="编号">${row.id}</#tr>
<#tr name="名称">${row.name}</#tr>
</#table>
</body>
</html>


让我们看看如何实现的

simple 标签

<h2>${tag.body}</h2>


与内置不同,获得标签体是调用tag.body, 也就是tag.getBody()方法

data 标签

data标签需要绑定变量,因此会在data.tag 脚本里调用本地方法@tag.binds 来绑定,然后tag.body执行,此处例子执行2次
<%
var name="ok";
var index = 1;
//绑定
@tag.binds(name,index);
for(var i=0;i<2;i++){
//执行标签体
%>
${tag.body} 
<%}%>


table 标签

可以调用tag.children获得标签体,然后分别执行标签体内容
<%
var trs = tag.children;
%>
<table>
<!--  显示表头 -->
<tr>
<% 
for(tr in trs){%>
<td><h2>${tr.name}</h2></td>
<%} %>
</tr>
<!--  显示数据 -->
<% for(row in tag.data) { 
//先绑定变量,这样tr能使用
@tag.binds(row);
%>
<tr>
<% for(tr in trs){ %>
    <td >${tr.body}</td>
<% } %>
<tr>
<%   } %>
</table>

转载于:https://my.oschina.net/xiandafu/blog/413529

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值