今天又被struts2的doubleselect标签困扰了一整个上午,令人费解,在此之前,已经试过被困扰一天的情况了,因此觉得有必要把doubleselect这个标签在运用的时候有关的注意事项写下来,警惕再犯!
先简单说一下doubleselect的用法(希望对初学者有所帮助) doubleselect最常用的结构为 <s:doubleselect list="" name="" listValue="" listKey="" doubleName="" doubleList="" doubleListValue="" doubleListKey=""></s:doubleselect> name 一级下拉菜单的名称 list 一级下拉菜单中的下拉链表,通常为hash的keyset() --详细见下面的代码部分 listValue 一级下拉菜单的可见属性 listKey 一级下拉菜单的属性值 doubleName 二级下拉菜单的名称(通常为要获取的参数,应与action中的属性名保持一致) doubleList 二级下拉菜单中的下拉链表,通常为hash中的top--详细见下面的代码部分 doubleListValue 二级下拉菜单中的可见属性 doubleListKey 二级下拉菜单中的属性值 forName doubleselect所对应的表单名,默认为当前表单,若不在表单中,或是没有指定的表单名不存在,则会报错! 举个通用的例子: 现有:国家表 country{country1,country2,country3} 城市表 city{{country1,city1},{country1,city2}, {country2,city1},{country2,city2}, {country3,city1},{country3,city2}} 国家表中只有一个关键字段country,而一个国家有多个城市,因此国家与城市间是一对多的关系 现在要通过选取国家来获得相应的城市,步骤如下: 1.创建国家链表 List<country> countryList = new ArrayList<country>(); 2.创建国家和城市关联的哈希表Map<country,List<city>> countryTocityMap = new HashMap(); 3.对country链表进行遍历,把每个国家对应的city链表添加到map里面去 for(Country country : countryList){ List<city> cityList = country.getCityList(); //具体的实现方法因人而异 countryTocityMap.put(country,cityList); //遍历的把多个城市“放”到一个国家里面去,形成对应关系 } 4.经历上面3个步骤就可以得到一个同时具有国家和城市的哈希表,下面可以对doubleselect来进行设置 <s:doubleselect name="country(自定义)" list="countryTocityMap.keySet()" listValue="name(country表里面的字段)" listKey="id(country表里面的字段)" doubleName="city(自定义)" doubleList="countryTocity[top]" doubleListValue="name(city表里面的字段)" doubleListKey="id(city表里面的字段)" forName="form1(指定的表单名一定要存在!)" ></s:doubleselect> 啰嗦太多了。。。其实今天困扰我的是一个令人很费解的问题,在将添加记录和修改记录集成在一个页面的时候,为贪图方便,我用了几个标志位判断,而后又为了偷懒,用了两个一模一样的doubleselect,问题就来了 添加的表单,我是在一进入页面的时候就加载了的,为了好看,放到了一个div里面先隐藏起来,而修改的表单则是通过修改的标志位进行判断,添加记录很顺利就完成了,但是修改记录的时候doubleselect就不联动了,在百思不得其解的时候,将doubleName改为不同的,结果出现一个很奇怪的现象,修改表单里的第二级下拉菜单只会停留在一开始选中的选项上面,不会有联动效果出现。。最后在修改了doubleselect的一级name之后。。。结果出来了 结论:当在同一个页面使用两个二级下拉菜单的时候,特别是在有间接传递参数的情况下,一级的名称是不可以相同的! |
|