struts2常用UI标签之:Form标签

一、select标签
(1)、静态构造下拉选项

<s:select name="user.sex" list="#{'0':'男','1':'女'}" label="性别" headerKey="" headerValue="请选择性别"></s:select>

注解:这里从页面来静态(也就是在页面中写死啦)构造下拉选项,关键点是list="#{'0':'男','1':'女'}" 通过它实现的select的两个option
headerKey指定缺省的选项"value",headerValue指定缺省的选项"text"

(2)、通过list对象动态构造下拉选项

<s:select label="书籍"
name="book"
list="books"
listKey="id"
listValue="name"
multiple="true"
size="3"
required="true"
/>

注解:这里通过一个list类型的对象来动态生成一个下拉列表。list="books"表示action里有一个list<Book>类型的books属性。listKey="id"表示当前option的value从books里的当前Book对象的id属性取值。listValue="name"表示当前option的text从books里的当前Book对象的name属性取值。

(3)、通过Map对象动态构造下拉选项

<s:select name="user.sex"
list="sexMap"
listKey="key"
listValue="value"
label="性别" headerKey="" headerValue="请选择性别"
></s:select>

注解:list="sexMap":表示action里有一个Map<String,String>类型的叫sexMap的属性。可以这样给它赋值:

sexMap = new HashMap();
sexMap.put("0", "男");
sexMap.put("1", "女");

listKey="key"和listKey="value"在这里是固定写法。对应sexMap的key和value

二、radio标签
(1)、静态构造单选项

<s:radio name="user.sex" list="#{'0':'男','1':'女'}" value="'0'"></s:radio>

注解:list="#{'0':'男','1':'女'}"在页面上静态构造了一个有两个项的单选项。value="'0'"是为这组单选项设置一个缺省项,即值为“0”文字为“男”的单选项会作为缺省选择项。注意,0一定要加上单引号,这样struts才不会去值栈里去找一个叫0的属性

(2)、通过map动态构造单选
<s:radio name="user.sex" list="sexMap" listKey="key" listValue="value" value="user.sex"></s:radio>

注解:list="sexMap":表示action里有一个Map<String,String>类型的叫sexMap的属性。可以这样给它赋值:

sexMap = new HashMap();
sexMap.put("0", "男");
sexMap.put("1", "女");

listKey="key"和listKey="value"在这里是固定写法。对应sexMap的key和value
value="user.sex"是为单选组指定缺省的选项。可以通过在action里为user.sex赋值来实现,例如:user.setSex("0");那么页面上值为“0”的那项就会被缺省选择上。

三、checkbox标签
struts2的checkbox比较有个性。
<s:checkbox label="性别" name="user.sex" value="true" fieldValue="dddd"/>
这里value的值是“假”值,fieldValue的值才是真值。当value="true"表示这个复选框被选上。为false时不选上
另外,它在向html转换后会多出一个隐藏域,很奇怪。上面的代码输出成html是这样的:
<input type="checkbox" name="user.sex" value="dddd" checked="checked" id="saveUser_user_sex"/>
<input type="hidden" name="__checkbox_user.sex" value="dddd" /> <label for="saveUser_user_sex" class="checkboxLabel">性别</label>


四、checkboxlist标签
与checkbox不同,该标签提供了类似radio和select的功能,也就是可以提供一组名称相同而值不同的控件。
(1)、静态构造一组复选框
<s:checkboxlist name="user.sex" list="#{'0':'男','1':'女'}" value="'0'"></s:checkboxlist>

注解:以上代码创建了一组包含两个checkbox,由于定义了value="'0'",所以由'0':'男'创建的checkbox将会被选择上。

(2)、通过Map对象动态创建一组复选框
<s:checkboxlist name="user.sex" list="sexMap" listKey="key" listValue="value"/>

注解:以上代码通过一个在action里定义的叫sexMap的Map对象动态创建一组复选框,用sexMap的key定义checkbox的value,用sexMap的value定义checkbox的label

五、datetimepicker标签
datetimepicker标签就是生成一个有日期控件的文本输入框。它有一个前提就是要在<head></head>内加一个"<s:head theme="ajax" />",然后可以在form内加上该标签。
(1)、静态构造有初始值的日期输入项
<s:datetimepicker name="user.birthday" label="出生日期" value="%{'2008-9-20'}"/>

(2)、动态构造有初始值的日期输入项
<s:datetimepicker name="user.birthday" label="出生日期" value="%{date}" displayFormat="yyyy-MM-dd"/>
在给输入项动态赋初始值时,要用ONGL的%{}表达式,而不能用#{}表达式。上面代码中的date变量需在action里有事选定义.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值