从JAVA / JSP中的哈希表键值中选择多个选项

时间:2013-07-08 09:24:31

标签: java jsp hashtable

注意:我正在遵循旧的jsp的scriptlet实践。请不要让我这次使用JSTL。

全部, 我有返回Map类型数据的方法 hashtable.keySet()返回[8, 5, 2] hashtable.entrySet()返回[8=ad, 5=asxd, 2=asdas]

然后我在jsp中选择了Multiple。 我想使用此MAP键值生成选择选项。 像这样

<select id="XX" name="XX" class="left" multiple="multiple">
  <option id="opt1" value="8">ad</option>
  <option id="opt2" value="5">asxd</option>
  <option id="opt3" value="2">asdas</option>
</select> 

编辑:这是我的地图类型方法

public Map<Integer, String> getRuleTag(String bucketTagGroup) {
          logger.debug("Start Of getRule Rule");


            Map<Integer, String> x = new Hashtable<Integer, String>();
            try
            {
                //System.out.println(rs.getString("inbuckets"));
                String[]  a = bucketTagGroup.split(", ");
                for(int i = 0;i<a.length;i++){
                //System.out.println(a[i]);
                    int tagid = Integer.parseInt(a[i]);
                    String sql1 = "select bucketchargetag from IDC.BCTCHRTAG where  tagid = ?";
                    java.sql.PreparedStatement p =  conn.prepareStatement(sql1);
                    p.setInt(1, tagid);
                    ResultSet rs1 = p.executeQuery();
                    while(rs1.next()){
                        //System.out.println(rs1.getString("bucketchargetag"));
                        x.put(tagid, rs1.getString("bucketchargetag"));
                        //System.out.println(x.entrySet());
                    }

                }
            logger.info(x.keySet().toString());
            } catch (SQLException e) {
                logger.debug(e.getMessage());
            }
            return x;
        }

PS:多个选择中的值可能会不时增加或减少。 将在运行时生成此多选。 请问我是否需要更多相关信息。 感谢。

1 个答案:

答案 0 :(得分:1)

<select id="XX" name="XX" class="left" multiple="multiple">
<%for(Integer key_value : (Integer)hashtable.keySet()){%>
  <option id="<%=key_value%>" value="<%=key_value%>"><%=hashtable.get(key_value)%></option>
<%}%>
</select>

试试这个。并尽量避免在jsp中使用sriptlets。这不是一个好习惯。