Struts2单选按钮标签s:radio的使用及其设置默认值

首先在页面中引入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的值的方法

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的设置无关

你可能感兴趣的:(struts,标签)