第一个下拉框选择城市后第二个下拉框自动显示相关的区域名字:
//城市对象
public class CityBean {
private int cityid;
private String cityname;
public int getCityid() {
return cityid;
}
public void setCityid(int cityid) {
this.cityid = cityid;
}
public String getCityname() {
return cityname;
}
public void setCityname(String cityname) {
this.cityname = cityname;
}
}
//区域对象
public class AreaBean {
private int areaid;
private String areaname;
private int cityid;
public int getAreaid() {
return areaid;
}
public void setAreaid(int areaid) {
this.areaid = areaid;
}
public String getAreaname() {
return areaname;
}
public void setAreaname(String areaname) {
this.areaname = areaname;
}
public int getCityid() {
return cityid;
}
public void setCityid(int cityid) {
this.cityid = cityid;
}
}
//action中代码
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import sf.bean.AreaBean;
import sf.bean.CityBean;
import com.opensymphony.xwork2.ActionSupport;
public class CityAction extends ActionSupport {
//map映射cityid--区域列表
private Map<Integer, List<AreaBean>> areaMap = new HashMap<Integer, List<AreaBean>>();
//list装所有city集合
private List<CityBean> cityBeans = new ArrayList<CityBean>();
public Map<Integer, List<AreaBean>> getAreaMap() {
return areaMap;
}
public void setAreaMap(Map<Integer, List<AreaBean>> areaMap) {
this.areaMap = areaMap;
}
public List<CityBean> getCityBeans() {
return cityBeans;
}
public void setCityBeans(List<CityBean> cityBeans) {
this.cityBeans = cityBeans;
}
public String select() throws Exception {
//组装数据
for (int i = 1; i <=3; i++) {
CityBean cityBean = new CityBean();
cityBean.setCityid(i);
cityBean.setCityname("cityname"+i);
cityBeans.add(cityBean);
List<AreaBean> areaBeans = new ArrayList<AreaBean>();
//i==1 j=1 2,3
//i==2 j=4 5 6
//i=3 j==7 8 9
for (int j = 3*i-2; j <= 3*i; j++) {
AreaBean areaBean = new AreaBean();
areaBean.setAreaid(j);
areaBean.setAreaname("area"+i+"-"+j);
areaBean.setCityid(i);
areaBeans.add(areaBean);
}
areaMap.put(i, areaBeans);
}
return "city";
}
}
//jsp页面写法
<h3>
使用s:doubleselect生成级联下拉列表框 必须要结合表单form一起使用 </h3>
<s:form action="userAction!add" method="POST" name="userForm"
namespace="/system">
<!-- theme:simple xhtml css_xhtml struts2不提供ajax -->
<table border="1" width="60%" bordercolor="#cc0000" cellspacing="0"
cellpadding="0">
<tr>
<td >
<!-- areaMap[top.cityid]: top是指前一个下拉框整个的选中项cityBean cityid就是指cityBean中cityid
所以areaMap[top.cityid]指map集合中第一个下拉框选中的id对应的list集合
list里面每个元素放的是AreaBean
-->
<s:doubleselect
tooltip="选择城市操作"
label="请选择城市"
name="city"
list="cityBeans"
listKey="cityid"
listValue="cityname"
doubleList="areaMap[top.cityid]"
doubleName="area"
doubleListKey="areaid"
doubleListValue="areaname"
/>
</td>
</tr>
</table>
</s:form>
doubleselect属性说明:
tooltip指显示图标的显示文字
label 指生成组件前的标签文字
name 指第一个下拉框的表单name属性
list 指第一个下拉框的集合
listKey 指第一个下拉框的选项的键值 提交后天的值 --对应集合里单个对象里面的属性
listValue 指第一个下拉框中的选项显示值 --对应集合里单个对象里面的属
doubleList 指第二个下拉框要使用的集合
doubleName 指第二个下拉框的表单name属性
doubleListKey 指第二个下拉框中的选项中的键值 --对应集合里单个对象里面的属性
doubleListValue 指第二个下拉框中的选项显示值 --对应集合里单个对象里面的属性
上面jsp代码出来的效果是两个下拉框分两行显示的如何让它们一行显示呢?比较简单的做法是:
定义样式:
<style type="text/css">
.doubleselect br{
display: none;
}
</style>
<div class="doubleselect">把<s:form>的代码放进来就好啦</div>
分享到:
相关推荐
4. **JSP页面**:在JSP页面中,使用`<s:doubleselect>`标签来声明这两个下拉列表。标签的属性包括`list`、`listKey`、`listValue`、`name`等,它们分别用来指定数据源、键字段、值字段以及Action中的属性名。 ```...
在上述示例的JSP代码中,`<s:doubleselect>`标签的`list`属性绑定到了`categoryList`,这应该是`Action`返回的`List<Dept>`,其中每个`Dept`对象包含部门ID(`id`)和部门名称(`deptName`)。`doubleList`则绑定到`...
在Struts2中,我们有许多内置的标签来帮助开发者更方便地处理表单元素,例如`<s:select>`和`<s:doubleselect>`就是其中两个用于创建下拉列表的标签。下面我们将详细探讨这两个标签以及如何在J2EE项目中使用它们。 1...
本文将详细介绍如何使用Struts2中的`<s:doubleselect>`标签来实现省市联动功能,并通过一个具体的业务场景来进行说明。 #### 二、业务场景分析 在代理商管理系统中,当新增代理商时需要选择其所属的省市。随后,当...
在JSP页面中,使用`<s:doubleselect>`标签,将Action中的`itemList`和`subitemMap`绑定到标签的`list`和`doubleList`属性上,完成二级联动下拉列表的展现。 总的来说,Struts2的`<s:doubleselect>`标签提供了一种...
本文详细介绍了Struts 2中 `<s:checkboxlist/>` 和 `<s:doubleselect/>` 这两个表单标签的使用技巧及常见问题的解决方案。通过这些技巧,开发者能够更加高效地利用这些标签来构建用户界面。未来,我们还将继续探索更...
5. <s:doubleselect list="" doubleName="" doubleList=""></s:doubleselect>-----双下拉框 E: 1. <s:if test=""></s:if> 2. <s:elseif test=""></s:elseif> 3. <s:else></s:else>-----这3个标签一起使用,...
4. **OGNL表达式**:在JSP页面中,我们可以使用OGNL表达式来获取Action中的属性,如`<s:doubleselect>`标签中的`list`、`listKey`、`listValue`等属性,都需要通过OGNL来绑定Action中的数据。 5. **`doubleselect`...
* <s:doubleselect>:双下拉框 E: * <s:if>:条件判断 * <s:elseif>:条件判断 * <s:else>:条件判断 F: * <s:fielderror>:显示文件错误信息 * <s:file>:文件上传 * <s:form>:获取相应 form 的值 G: * ...
在JSP页面中,使用`<s:doubleselect>`标签来渲染这两个下拉列表。标签的属性包括但不限于`list`(父级选项)、`listKey`(父级选项的键)、`listValue`(父级选项的显示值)、`doubleList`(子级选项的映射)、`...
在本篇文章中,我们将深入探讨Struts2框架中的`doubleselect`标签的使用方法,并结合一个具体的示例来展示如何将此标签与Hibernate和Spring框架整合在一起,以便于更好地理解和运用这一技术。 ### Struts2框架简介 ...
5. `<s:doubleselect list="" doubleName="" doubleList=""></s:doubleselect>` - 双下拉框,用于双向选择关联数据。 E部分: 1. `<s:if test="">`、`<s:elseif test="">`、`<s:else>` - 条件判断标签,用于根据...
5. `<s:doubleselect>`:双列选择框,用于两个下拉列表之间的数据关联。 E组标签: 1. `<s:if>`、`<s:elseif>`、`<s:else>`:条件判断标签,实现条件语句。 F组标签: 1. `<s:fielderror>`:显示字段级别的错误...
- `<s:doubleselect>`:创建两个关联的下拉框,常用于一对多关联的选择。 - `<s:optiontransferselect>`:创建两个独立的下拉框,支持元素的转移。 4. **表单元素**: - `<s:file>`:处理文件上传功能。 - `<s:...
12. `s:doubleselect` 标签:这是一个双列选择标签,允许用户在两个列表之间进行选择并交换元素。 除此之外,Struts 2还提供了许多其他标签,如`s:textfield`用于输入文本,`s:textarea`用于多行文本输入,`s:...
5. `<s:doubleselect>`:创建双列选择框,允许用户从两个列表中选择值。 E部分: 1. `<s:if>`,`<s:elseif>`,`<s:else>`:条件判断语句,用于控制标签的渲染。 F部分: 1. `<s:fielderror>`:显示字段级别的错误...
`<s:generator>` 标签配合`<s:iterator>`使用,用于生成迭代所需的初始数据。 ### 18. `<s:head>` 标签 `<s:head>` 标签用于包含HTML头部信息,如CSS和JS文件的引用。 ### 19. `<s:hidden>` 标签 `<s:hidden>` ...
- `<s:doubleselect>`:创建两个关联的下拉框。 - `<s:elseif>`、`<s:else>`:进行条件判断。 - `<s:fielderror>`:显示字段级别的错误信息。 - `<s:file>`:处理文件上传。 这只是Struts2标签库的一小部分,实际中...
具体来说,需要实现`findSort_`方法,该方法用于从数据库中查询数据,并将其封装成适合`doubleSelect`使用的格式。 ```java public String findSort_(){ try{ pslist = service.findSortOne(); List...