首页 web前端 html教程 简单扩展让beetl HTML标签支持父子嵌套_html/css_WEB-ITnose

简单扩展让beetl HTML标签支持父子嵌套_html/css_WEB-ITnose

Jun 24, 2016 am 11:49 AM

默认情况下,Beetl的html标签并不支持父子嵌套,就像类似jsp标签那样,父标签需要知道子标签的信息,子标签也需要知道父标签信息。但是beetl只需要简单扩展,就能完成嵌套标签支持。

首先看一个最终的使用效果,实现俩个html标签table.tag,tr.tag.可以在页面上这么用:

<#table data ="${userList}"><#tr class="3c" name="name"> 名称 </#tr></#table>
登录后复制



在阅读table.tag,tr.tag之前,先看看如何扩展html标签
首先,需要扩展 HTMLTagSupportWrapper,这个类是html标签实现类,我们可以扩展此类来定制化需求,然后重新注册覆盖。因此实现类

public class HTMLNestTagSupportWrapper extends HTMLTagSupportWrapper{public void render(){....}}
登录后复制



然后在配置文件配置TAG.htmltag= bingo.util.HTMLNestTagSupportWrapper 就可以生效。

HTMLNestTagSupportWrapper用到了TagNestContext类,这个类其实就是一个树形结构,记录了parent的Context,记录了当前tag信息,以及记录了子tag的Context,这样,每个tag都可以访问父tag或者子tag:代码如下

public class TagNestContext {private  Tag tag = null;private TagNestContext parent = null;private List<TagNestContext> children = null;public  Tag getTag() {    return tag;}public void setTag(Tag para) {    this.tag = para;}public TagNestContext getParent() {    return parent;}public void setParent(TagNestContext parent) {    this.parent = parent;}public List<TagNestContext> getChildren() {    if(children==null) children = new ArrayList<TagNestContext>();    return children;}public void setChildren(List<TagNestContext> children) {    this.children = children;}}
登录后复制



回头在看看 HTMLNestTagSupportWrapper实现

public void render(){    HttpServletRequest request = (HttpServletRequest)this.ctx.getGlobal("request");    TagNestContext tnc = (TagNestContext)request.getAttribute("tagContext");    if(tnc==null){        tnc = new TagNestContext();        tnc.setTag(this);        request.setAttribute("tagContext", tnc);        super.render();        request.removeAttribute("tagContext");    }else{        TagNestContext child = new TagNestContext();        child.setParent(tnc);        child.setTag(this);        tnc.getChildren().add(child);        request.setAttribute("tagContext", child);        super.render();        //重新设置        request.setAttribute("tagContext", child.getParent());    }}public String getTagName(){    return (String)this.args[0];}public Object get(String attr){    Map map =  (Map)this.args[1];    return map.get(attr);}
登录后复制



如上代码所示,但渲染某个htmltag前(调用super.render()前),可以从request里获取NestContext,如果没有,生成一个新的NestContext。如果已经存在。则将当前NestContext加入到父NestContext。渲染完毕后,需要重置NestContext。

最后看一下tr.tag如何实现,tr仅仅实现了生成表头

<tr class="${class}">${tagBody}</tr>
登录后复制



table.tag 则要麻烦点,需要知道有多少个tr,然后输出数据,内容如下:

<table>${tagBody}<% for(var item in data){%><tr><%var tag = getTagContext();var children = tag.children;for(var tdTagCtx in children){    print("<td>");    var tdTag = tdTagCtx.tag;    var name = tdTag.tagName;    var value = item[name];    print(value);    println("</td>");}%></tr><%} %></table>
登录后复制



etTagContext 是一个注册方法,获取当前context.可以自行开发一个
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

公众号网页更新缓存难题:如何避免版本更新后旧缓存影响用户体验? 公众号网页更新缓存难题:如何避免版本更新后旧缓存影响用户体验? Mar 04, 2025 pm 12:32 PM

公众号网页更新缓存难题:如何避免版本更新后旧缓存影响用户体验?

如何使用HTML5表单验证属性来验证用户输入? 如何使用HTML5表单验证属性来验证用户输入? Mar 17, 2025 pm 12:27 PM

如何使用HTML5表单验证属性来验证用户输入?

如何高效地在网页中为PNG图片添加描边效果? 如何高效地在网页中为PNG图片添加描边效果? Mar 04, 2025 pm 02:39 PM

如何高效地在网页中为PNG图片添加描边效果?

&lt; iframe&gt;的目的是什么。 标签?使用时的安全考虑是什么? &lt; iframe&gt;的目的是什么。 标签?使用时的安全考虑是什么? Mar 20, 2025 pm 06:05 PM

&lt; iframe&gt;的目的是什么。 标签?使用时的安全考虑是什么?

使用IFRAME的安全性含义是什么?如何减轻它们? 使用IFRAME的安全性含义是什么?如何减轻它们? Mar 18, 2025 pm 02:51 PM

使用IFRAME的安全性含义是什么?如何减轻它们?

我如何使用html5&lt; meter&gt; 要在范围内显示数值数据的元素? 我如何使用html5&lt; meter&gt; 要在范围内显示数值数据的元素? Mar 12, 2025 pm 04:08 PM

我如何使用html5&lt; meter&gt; 要在范围内显示数值数据的元素?

HTML5中跨浏览器兼容性的最佳实践是什么? HTML5中跨浏览器兼容性的最佳实践是什么? Mar 17, 2025 pm 12:20 PM

HTML5中跨浏览器兼容性的最佳实践是什么?

如何有效地使用HTML链接进行导航和SEO? 如何有效地使用HTML链接进行导航和SEO? Mar 18, 2025 pm 02:39 PM

如何有效地使用HTML链接进行导航和SEO?

See all articles