4、视图
有几种作为视图的技术可以使用:
l JSP:这是Java Web开发者熟悉的技术,可以作为通用选择;本教程介绍在JSP中使用WebWork的标记库
l Velocity:一种基于Java的模板引擎,提供简单而强大的模板语言VTL来替代JSP,将Java代码从Web页面中分离
l Freemaker:对于MVC模式设计,另外一种可以替代JSP的基于Java的模板引擎,但兼容JSP标记
4.1、使用JSP作为视图
使用JSP呈现视图,可以使用Scriptlets或WebWork标记来访问Action的数据。推荐使用WebWork标记库。
(1)使用Scriptlets访问Acition的数据
在Scriptlets中是使用Value Stack对象访问Action的数据的,下面是使用Scriptlets实现上节中第二个例子的结果输出页面:
<%@ page import="com.opensymphony.xwork.util.OgnlValueStack" %>
<html>
<head>
<title>WebWork Tutorial - Lesson 4.1 - Lesson 3's example modified</title>
</head>
<body>
<%
OgnlValueStack stack = (OgnlValueStack)request.getAttribute("webwork.valueStack");
out.write("Hello, " + stack.findValue("person"));
%>
</body>
</html>
然而,推荐使用WebWork标记,就象上节中第二个例子使用<ww:property />做的那样,具有清晰的语法,并能在Value Stack对象不存在时处理。
(2)使用WebWork标记库
WebWork标记库可以分为7类:
l 通用标记:最常用的基本标记;
l 组件标记:在视图中生成组件;
l 流程控制标记:控制JSP中的流程;
l Iteration标记:遍历访问元素或操作可遍历对象;
l UI标记:生成HTML表单域和控制;
l VUI标记:(需要志愿者来编写);
l 国际化标记:使视图具有国际化;
(1)通用标记
<ww:property />
获得结果属性值;如果值不存在,返回Value Stack 中最顶上的值
<ww:push />
将值推入Value Stack
<ww:param />
设置父标记的参数(属性)值;该标记只能在其它标记内部使用
<ww:set />
设置Value Stack 中具有指定范围(page, stack, application, session)的对象值;如果没有指定值,使用Value Stack 中最顶上的值
<ww:url />
创建编码的URL
(2)组件标记
<ww:action />
在taglib的上下文中执行一个Action ,标记体用来显示Action 的响应结果
<ww:bean />
在ActionContext 中创建一个JavaBean,实例化它的属性,以便以后使用
<ww:include />
包含另外一个页面或Action
(3)流程控制标记
<ww:if />
如果条件标记的布尔表达式为true ,计算标记体的内容
<ww:else />
如果前面条件标记的布尔表达式为false,计算标记体的内容
<ww:elseif />
如果前面条件标记的布尔表达式为false,而本条件标记的布尔表达式为true,计算标记体的内容
(4)Iteration标记
<ww:iterator />
遍历一个集合
<ww:generator />
生成遍历对象
<ww:append />
追加遍历对象
<ww:subset />
获得遍历对象的子集
<ww:merge />
合并几个遍历对象为一个.
(5)UI标记
生成HTML表单控件的UI标记和WebWork核心紧密集成,标记被设计为最小化编译代码逻辑的数量和使用模板系统呈现HTML的代表。UI标记覆盖了大部分常用标记,而且提供了一个组件标记,用来创建定制组件。UI标记还提供了显示内联错误信息的内建支持。有关UI标记的详细介绍,在下一节中讲述。
(6)VUI标记
需要志愿者来编写。
(7)国际化标记
<ww:text />
打印出国际化字符串
<ww:i18n />
将一个资源包放到Value Stack中, 以便<ww:text />标记使用