EasyJWeb­-Velocity脚本简明教程


EasyJF 团队普通文档通用模板 简易java 框架开源团队www.easyjf.com 1 EasyJWeb­Velocity 脚本简明教程 很多人下载了 EasyJWeb 的开源应用示例,但是对动态页面模板文件中的标签使用不是 很熟悉,这里简单介绍一下。EasyJWeb 特定把视图限定为 Velocity,因为我们觉得在Velocity 在表现上从可维护性、简洁性乃灵活性上,比 JSP 及其它视力技术表现强得多。虽然我们可 以非常简单把 EasyJWeb 扩展成支持多种视力技术,但当前我们不打算这样做! 使用 EasyJWeb 的目的,是在于把页面-程序完成分开,就也就是一个项目中,程序员 使用专业 Java 开发工具(如 Eclipse、JBuilder 等)来编写、调试、测试程序,页面制作人员 使用专业的网页制作工具(如 Macromedia Dreamweaver)来设计制作网页,而两者之间的 协调通过一个规范的接口协议来解决。需要在页面里面加如一些标签,来生成动态内容,这 一工作可以交由网页制作人员来完成。因为使用 Velocity 作为视图,由于他的语法、功能及 使用方法都比较简单,因此一般情况下,一天以内就能让页面制作人员熟练掌握其用法。 Velocity 是一个基于 java 的模板引擎(template engine),它允许任何人仅仅简单的使用 模板语言(template language)来引用由 java 代码定义的对象。作为一个比较完善的模板引 擎,Velocity 的功能是比较强大的,但强大的同时也增加了应用复杂性。 一、基本语法 1、"#"用来标识 Velocity 的脚本语句,包括#set、#if 、#else、#end、#foreach、#end、 #iinclude、#parse、#macro 等; 如: #if($info.imgs) #else #end 2、"$"用来标识一个对象(或理解为变量);如 如:$i、$msg、$TagUtil.options(...)等。 3、"{}"用来明确标识 Velocity 变量。 比如在页面中,页面中有一个$someonename,此时,Velocity 将把 someonename 作为变 量名,若我们程序是想在 someone 这个变量的后面紧接着显示 name 字符,则上面的标签应 该改成${someone}name。 4、"!"用来强制把不存在的变量显示为空白。 如当页面中包含$msg,如果msg 对象有值,将显示msg 的值,如果不存在msg 对象同, 则在页面中将显示$msg 字符。这是我们不希望的,为了把不存在的变量或变量值为 null 的 对象显示为空白,则只需要在变量名前加一个“!”号即可。 如:$!msg 二、在 EasyJWeb 中的最佳实践 EasyJF 团队普通文档通用模板 简易java 框架开源团队www.easyjf.com 2 理论上你可以在 EasyjWeb 模板使用所有 Velocity 的脚本及功能,但我们不推荐你在界 面模板中使用过多过复杂的脚本表达方式,在万不得已的情况下,不要在界面模板中加入任 何复杂的逻辑,更不要在界面模板中加入变量声明、逻辑运算符等等。 在EasyJWeb 中,我们提供了五条基本的模板脚本语句,基本上就能满足所有应用模板 的要求。这四条模板语句很简单,可以直接由界面设计人员来添加。在当前很多 EasyJWeb 的应用实践中,我们看到,所有界面模板中归纳起来只有下面四种简单模板脚本语句即可实 现: 1、$!obj 直接返回对象结果。 如:在 html 标签中显示 java 对象 msg 的值。

$!msg

在html 标签中显示经过HtmlUtil 对象处理过后的msg 对 象 的 值.

$!HtmlUtil.doSomething($!msg)

2、#if($!obj)#else #end 判断语句 如:在 EasyJWeb 各种开源应用中,我们经常看到的用于弹出提示信息 msg 的例子。 #if($msg) #end 上面的脚本表示当对象 msg 对象存在时,输出 #end 上面的脚本表示当对象 msg 对象存在时,输出