首先,还是要真心的感谢kingthy能为我们提供Vtemplate这么一款优秀的模板引擎...
本篇文章主要记录自己对该模板引擎的初次的体会. 如果各位看官觉得有问题,欢迎指出..
(注:此类模板引擎和我们.net程序员经常接触的.aspx这套引擎针对的场景一般有些区别,所以暂且不谈与.aspx的比较)
在使用过程中,暂且觉得Vtemplate至少有以下几个明显的优势:
1.>语法简单,基本上能接受html标签就可以接受该模板引擎的大部分控制元素.(这一点有时相当重要,因为用户不都是懂后台的程序员)
2.>开源,代码可读性强.(本人不是什么牛人,但稍微接触一段时间后,即可从标签基类派生一些自定义的标签)
3.>性能良好,可维护性强(记得部分开源产品,对标签,属性的处理是每一个都进行全文的正则表达式处理,来回倒腾)
4.>支持文档丰富,也存在QQ群.
下面举一个自己扩展的例子:
a.>来自织梦的一个标签应用示例:
{dede:booklist row='12' booktype='-1' orderby='lastpost' author='' keyword=''}//织梦的用户很多,习惯这种简单的调用.也是我的目标
<a href='[field:bookurl /]'>[field:bookname /]</a><br />
{/dede:booklist}
b.>来自Vtemplate的类似标签应用示例(系统默认的方案)
<vt:function var="hotlinks" method="GetLinkList" type="$testLinkListObject" args="4" />//声明变量并规定值得获取方式
<vt:foreach from="$hotlinks" item="link">
<a href='{$#.link.url}'>{$#.link.name}</a>
</vt:foreach>
c.>利用Vtemplate提供的重写与派生,改造后的标签应用示例
<vt:linklist rows="2" item="link"> //可以让用户不考虑使用哪个类的实例,哪个方法,以及单独定义一个function区域规定foreach的from变量.
<a href='{$#.link.url}'>{$#.link.name}</a>
</vt:linklist>
刚开始以为很复杂,后来稍微看了Vtemplate作者的源代码,发现,其实系统已经给我们提供了很多。我们要做的基本上就是如下所述:
1.>在TagFactory.FromTagName方法中加上一个switch的case,返回你的一个自定义Tag类的实例.
2.>假设你要给书本定义个标签,因为书本有作者,价格,出版社这些信息,所以标签就会有这些属性.你可以在booklist标签中定义.
这个booklist需要继承自Tag. 一般情况下,为了圈定呈现的范围,我们这标签肯定是有结为标签的,重写IsSingleTag为false.
3.>迭代属性定义中,你可以参考foreach标签,保留其中的Item,Index,这两个会在循环用到的.
4.>在呈现标签元素的方法RenderTagData中,你可以把foreach中取自From规定变量的值改为自己实现的一个对象,这个对象应该实现
IEnumerable接口.
接下来你可以测试了,你会发现无论定使用几次,这个自定义的标签,都会工作良好,不过请注意其中的item属性不可少. .