freemarker的模板标签获取
2016-07-29 00:00
495 查看
In FreeMarker 2.2, Template has an undocumented method for examining the parsed template: getRootTreeNode 使用freemarker模板引擎进行传统的开发有个固定的模式就是我们知道模板上有哪些标签,然后我们会获取这些标签的数据来进行data+model的组合。但是如果模板上的标签名字或者个数不确定的话,那么我们就需要知道模板上到底有那些标签了。这样做的好处有以下几个方面:
1、我们可以根据模板实际拥有的标签来进行数据获取,避免了将整个系统的标签都穷举一遍,分别查取数据
2、我们可以分析获取到的标签名字,根据标签名字来做逻辑
但是freemarker2.2官方的faq列表的第26项中确是明确的说不想支持这个功能。但是又很猥琐的提出了一个解决方案,就是将模板的各个数据项进行了拆分。提供一个半公开的访问接口。
通过查看Template的源代码发现,她将那个模板标签封装的是十分严密,对外提供的方法和类都是包内可见,实在是让人难以入手。最后不得不想个歪招将我们要的标签给打印出来了。如下
如上的方式,这种方式实在是蹩脚,希望freemarker尽快出一个直接获取他自己模板上的标签的方法。省的我在这费时费力的比对。
1、我们可以根据模板实际拥有的标签来进行数据获取,避免了将整个系统的标签都穷举一遍,分别查取数据
2、我们可以分析获取到的标签名字,根据标签名字来做逻辑
但是freemarker2.2官方的faq列表的第26项中确是明确的说不想支持这个功能。但是又很猥琐的提出了一个解决方案,就是将模板的各个数据项进行了拆分。提供一个半公开的访问接口。
In FreeMarker 2.2, Template has an undocumented method for examining the parsed template: getRootTreeNode
通过查看Template的源代码发现,她将那个模板标签封装的是十分严密,对外提供的方法和类都是包内可见,实在是让人难以入手。最后不得不想个歪招将我们要的标签给打印出来了。如下
Template t = getFreeMarkerCFG().getTemplate(templateFileName); //获取所有的标签项 TemplateElement te=t.getRootTreeNode(); for(Enumeration children = te.children(); children.hasMoreElements();){ Object obj=children.nextElement(); if("class freemarker.core.DollarVariable".equals(obj.getClass().toString())){ System.out.println(obj.toString()); } }
如上的方式,这种方式实在是蹩脚,希望freemarker尽快出一个直接获取他自己模板上的标签的方法。省的我在这费时费力的比对。
相关文章推荐
- linux下的memcache的线程配置
- 火车票订票系统的几点优化思考
- ofbiz的webservice接口提供(3)-wsdl文件的不规范性
- android中使用httpclient提交表单
- 消息摘要算法-MAC算法系列
- springframework(九)AOP的advices,中规中矩的使用方式
- 第三章:Creating Applications and activities-(一)什么组成了一个Android应用
- memcache集群使用原则
- glassfish 安装
- 邮件营销相关技术知识
- ofbiz的webservice接口提供(3)-不规范的wsdl的客户端访问代码
- EXECUTE IMMEDIATE 使用小结
- Activemq(1)
- memcache的一致性hash算法使用
- 抄袭的人是可耻的
- zookeeper典型使用场景
- “抄袭事件”判决书
- linux下根据日期创建文件或者文件夹
- apache的博客roller的url重写功能,以及apache的二级域名配置
- ldd 的一个安全问题