首先在页面中引入struts标签库:
<%@ taglib prefix="s" uri="/struts-tags"%>
在JSP页面中创建单选按钮radio的方法:
<s:radio list="#{'1':'先生','0':'女士'}" name="gender" value="1"/>
其中list中的键值对表示所有的选项,value表示设置的默认值,如果这个默认值是从后台传过来的,可以这样设置:
<s:radio list="#{'1':'先生','0':'女士'}" name="gender" value="#{buyer_gender }"/>
注意这里使用的是 # 符号而不是 $ 。
s:radio的值得获取也非常的简单,如果是在struts2的action则直接使用标签的name属性即可获得:
首先声明一个属性,名称为radio的name,再添加getter和setter方法:
String gender; public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; }
这样就可以直接取得选择的值了。(选择的值为标签的list属性的键值对的key,如上面的1或0)
补充:
遇到的问题:在使用该标签时,设置了默认选中项,但提交数据返回后,单选框不能显示之前选中的项,仍然为默认选项
通过测试得出以下结论:
以<s:radio name="user.sex" list="%{#{'1':'男','0':'女'}}" theme="simple"></s:radio>为例
在使用s:radio标签的时候,如果要使该标签默认选中一项,可以通过两种方法
1、通过js代码实现
document.getElementsByName('user.sex')[0].checked=true;//默认选中男
2、通过添加value属性
<s:radio name="user.sex" list="%{#{'1':'男','0':'女'}}" value="1" theme="simple"></s:radio>
在通过value属性设置单选框的默认选项时,无论何时页面刷新后单选框的状态都是选中该默认项
因此,如果要让数据提交后台后,该单选框仍然是之前选中的项,不能通过value属性设置它的默认项,应该通过第一种方法设置
此外,后台能够正确获取该单选框的值,而与value的设置无关