Struts2的表单标签
Struts2 的表单标签用于向服务器提交用户输入的信息,绝大多数的表单标签都有其对应的 HTML 标签。读者可以结合 HTML 的标签对比学习 Struts2 的表单标签。
表单标签的公共属性
每一个表单标签在 Struts2 核心 JAR 文件的 org.apache.struts2.components 包中都有一个对应的类,这些对应的类都继承自 UIBean 类。
UIBean 类提供了一组公共属性,这些属性是所有表单标签的通用属性,具体如表 1 所示。
属性名 | 主题 | 数据类型 | 说 明 |
---|---|---|---|
title | simple | String | 设置表单元素的 title 属性 |
disabled | simple | String | 设置表单元素是否可用 |
label | xhtml | String | 设置表单元素的 label 属性 |
labelPosition | xhtml | String | 设置 label 元素的显示位置,可选值为 top 和 left(默认) |
name | simple | String | 设置表单元素的 name 属性,与 Action 中的属性名对应 |
value | simple | String | 设置表单元素的值 |
cssClass | simple | String | 设置表单元素的 class |
cssStyle | simple | String | 设置表单元素的 style 属性 |
required | xhtml | Boolean | 设置表单元素为必填项 |
requiredposition | xhtml | String | 设置必填标记(默认为*)相对于 label 元素的位置,可选值为 left 和 right(默认) |
tabindex | simple | String | 设置表单元素的 tabindex 属性 |
除了这些常用的通用属性以外,表单标签还有很多其他属性。由于篇幅有限,这里就不再一一列举。
需要注意的是,表单标签的 name 和 value 属性基本等同于 HTML 组件的 name 和 value,但也有所不同:表单标签在生成 HTML 时,如果标签没有设置 value 属性,则会从值栈中按照 name 获取相应的值,并把这个值设置成 HTML 组件的 value。
简单而言,就是表单标签的 value 在生成 HTML 时会自动设置值,而这个值是从值栈中获取的。关于值栈问题教程后面会进行讲解。
<s:form>标签
<s:form> 标签用于呈现 HTML 语言中的表单元素,其常用属性如表 2 所示。
属性名 | 是否必填 | 类 型 | 说 明 |
---|---|---|---|
action | 否 | String | 指定提交时对应的 action,不需要 action 后缀 |
enctype | 否 | String | HTML 表单 enctype 属性 |
method | 否 | String | HTML 表单 method 属性 |
namespace | 否 | String | 所提交 action 的命名空间 |
在使用 <s:form> 标签时,一般会包含其他的表单元素,如 <s:textfield> 和 <s:radio> 等标签。在提交表单时,这些表单元素对应的 name 属性,将其作为参数传入 Struts2 框架进行处理。
<s:textfield>和<s:textarea>标签
<s:textfield> 和 <s:textarea> 标签的作用比较相似,都用于创建文本框,其主要区别在于 <s:textfield> 创建的是单行文本框,而 <s:textarea> 创建的是多行文本框。二者的使用也比较简单,一般只需要指定其 label 和 name 属性即可。两个标签的用法如下所示。
<s:textfield> 标签的用法:
<s:textfield label="用户名" name="username"/>
<s:textarea> 标签的用法:
<s:textarea label="描述" name="description"/>
在上述两个用法中,name 属性用于指定单行/多行文本框的名称,在 Action 中,通过 name 属性即可获取单行/多行文本框的值。
此外,<textarea> 标签还可以通过 value 属性指定单行/多行文本框的当前值,通过 cols 和 rows 属性分别指定多行文本框的列数和行数。
<s:passWord>标签
<s:password> 标签用于创建一个密码输入框,它可以生成 HTML 中的 <input type="password"/> 标签。<s:password> 标签的常用属性说明如表 3 所示。
属性名 | 说 明 |
---|---|
name | 用于指定密码输入框的名称 |
size | 用于指定密码输入框的显示宽度,以字符数为单位 |
maxlength | 用于限定密码输入框的最大输入字符串个数 |
showPassword | 是否显示初始值,即使显示也仍为密文显示,用掩码代替 |
<s:password> 标签的使用方法如下所示:
<s:password label="password" name="password" maxlength="20"/>
需要注意的是,Struts2 的 <s:password> 标签与 HTML 的 <input type="password"/> 标签也略有不同:<input type="password"/> 标签只要设置 value 属性就可以将 value 的属性值作为默认显示值;而 Struts2 的 <s:password> 标签除了要设置 value 属性值以外,还要设置 showPassword 属性值为 true。
<s:radio>标签
<s:radio> 标签用于创建单选按钮,生成 HTML 中的 <input type="radio"/> 标签。<s:radio> 标签的常用属性说明如表 4 所示。
属性名 | 是否必填 | 类 型 | 说 明 |
---|---|---|---|
list | 是 | Collection,Map Enmumeration,Iterator,Array | 用于生成单选框中的集合 |
listKey | 否 | String | 指定集合对象中的哪个属性作为选项的 value |
listValue | 否 | String | 指定集合对象中的哪个属性作为选项的内容 |
表 4 中的三个属性必须要配合使用,由 list 属性指定从集合中获得元素,由 listKey 属性指定获得元素之后使用元素的哪个属性作为生成 <input type="radio"/> 的 value 属性,由 listValue 属性指定生成的 <input type="radio"/> 后展示给用户的内容。
<s:reset>标签
<s:reset> 标签用于创建一个重置按钮,会生成 HTML 中的 <input type="reset"/> 标签,该标签的使用比较简单,其常用属性为 name 和 value。
其中,name 属性用于指定重置按钮的名称,在 Action 中,可以通过 name 属性获取重置按钮的值,value 属性用于显示按钮的值。该标签的用法如下所示:
<s:reset value="reset"/>
<s:reset name="reset" value="重置"/>
<s:submit>标签
<s:submit> 标签主要用于产生 HTML 中的提交按钮,该表单元素中,可以指定提交时的 Action 对应的方法。该标签通常与 <s:form> 标签一起使用,该标签的常用属性如表 5 所示。
属性名 | 是否必填 | 类型 | 说明 |
---|---|---|---|
action | 否 | String | 指定提交时对应的 Action |
method | 否 | String | 指定 Action 中调用的方法 |
下面通过简单的用户注册案例,演示前几个小节中所讲解的标签的使用。在 struts2Demo04 项目的 WebContent 目录下创建一个名称为 register.jsp 的文件,编辑后如下所示。
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@taglib prefix="s" uri="/struts-tags" %> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>用户注册</title> </head> <body> <s:form action=""> <s:textfield name="" label="昵称"/> <s:textfield name="" label="用户名"/> <s:password name="" label="密码"/> <s:password name="" label="确认密码"/> <s:radio name="" label="性别" list="#{0:'男',1:'女'}" listKey="key" listValue="value" value="0"/> <s:textarea label="个性签名" name="" rows="17" cols="3"/> <s:reset value="重置"/> <s:submit value="注册"/> </s:form> </body> </html>
上述代码中,分别使用了 <s:form>、<s:textfield>、<s:textarea>、<s:password>、<s:radio>、<s:reset> 和 <s:submit> 共 7 种标签编写了一个表单页面。
在 <s:radio> 标签中,使用 list 属性定义了一个 Map 集合,并使用 value 属性指定其默认显示值为男(value = 0 表示集合中 key 为 0 的元素)。在 <s:textarea> 标签中,使用 rows 属性和 cols 属性定义了多行文本框的列数为 3,行数为 17。
启动项目后,在浏览器的地址栏中输入地址 http://localhost:8080/struts2Demo04/register.jsp 访问 register.jsp,浏览器的显示结果如图 1 所示。
发表评论