一、select标签
(1)、静态构造下拉选项
- <s:select name="user.sex" list="#{'0':'男','1':'女'}" label="性别" headerKey="" headerValue="请选择性别"></s:select>
<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"
- />
<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>
<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", "女");
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>
<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>
<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", "女");
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"/>
<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>
<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>
<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"/>
<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'}"/>
<s:datetimepicker name="user.birthday" label="出生日期" value="%{'2008-9-20'}"/>
(2)、动态构造有初始值的日期输入项
- <s:datetimepicker name="user.birthday" label="出生日期" value="%{date}" displayFormat="yyyy-MM-dd"/>
<s:datetimepicker name="user.birthday" label="出生日期" value="%{date}" displayFormat="yyyy-MM-dd"/>
在给输入项动态赋初始值时,要用ONGL的%{}表达式,而不能用#{}表达式。上面代码中的date变量需在action里有事选定义.