[转载]Vtemplate模板引擎的使用心得 - 黄岛主 - 博客园

[转载]对kingthy创作的Vtemplate模板引擎的使用心得 – 黄岛主 – 博客园.

首先,还是要真心的感谢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>&nbsp;&nbsp;&nbsp;
</vt:foreach>

c.>利用Vtemplate提供的重写与派生,改造后的标签应用示例

<vt:linklist  rows=”2″ item=”link”>   //可以让用户不考虑使用哪个类的实例,哪个方法,以及单独定义一个function区域规定foreach的from变量.
<a href='{$#.link.url}’>{$#.link.name}</a>&nbsp;&nbsp;&nbsp;
</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属性不可少. .

赞(0) 打赏
分享到: 更多 (0)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏