WebWork2教程(中文版)(4.1)

4、视图

有几种作为视图的技术可以使用:

l         JSP:这是Java Web开发者熟悉的技术,可以作为通用选择;本教程介绍在JSP中使用WebWork的标记库

l         Velocity:一种基于Java的模板引擎,提供简单而强大的模板语言VTL来替代JSPJava代码从Web页面中分离

l         Freemaker对于MVC模式设计另外一种可以替代JSP的基于Java的模板引擎,但兼容JSP标记

4.1、使用JSP作为视图

使用JSP呈现视图,可以使用ScriptletsWebWork标记来访问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,计算标记体的内容

4Iteration标记

<ww:iterator />

遍历一个集合

<ww:generator />

生成遍历对象

<ww:append />

追加遍历对象

<ww:subset />

获得遍历对象的子集

<ww:merge />

合并几个遍历对象为一个.

5UI标记

生成HTML表单控件的UI标记和WebWork核心紧密集成,标记被设计为最小化编译代码逻辑的数量和使用模板系统呈现HTML的代表。UI标记覆盖了大部分常用标记,而且提供了一个组件标记,用来创建定制组件。UI标记还提供了显示内联错误信息的内建支持。有关UI标记的详细介绍,在下一节中讲述。

6VUI标记

需要志愿者来编写。

7)国际化标记

<ww:text />

打印出国际化字符串

<ww:i18n />

将一个资源包放到Value Stack, 以便<ww:text />标记使用

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值