关于web中下拉列表的几种实现方法

ZDNet软件频道 时间:2008-06-29 作者: | 中国IT实验室 我要评论()
本文关键词:实现 web JSP
 从数据库中获得数据List,将数据放到Request里面使用setAttribute(”AList”,AList
 总结一下关于web上使用下拉框的情况
  
  从数据库中获得数据List,将数据放到Request里面使用setAttribute(”AList”,AList)
  
  A中有2个属性(String id,String value)
  
  1.使用JSTL的forEach方式
  <select name=”xx” ……..>
  <c:forEach items="$" var="p" >
  <c:choose>
  <c:when test="${xxx == p.id}">
  <option value='<c:out value="$"/>' selected="selected">
  <c:out value="$"/>
  </option>
  </c:when>
  <c:otherwise>
  <option value='<c:out value="$"/>'>
  <c:out value="$"/>
  </option>
  </c:otherwise>
  </c:choose>
  <c:forEach>
  </select>
  
  2.使用struts的标签
  <html:select property=”xxx”>
  <html:options collection="AList" labelProperty="value" property="id" />
  </html:select>
  
  查一下struts的api文档,可以看到select 中选项有3 taglib可以使用。
  
  第一种直接使用把所有选项写在中间。
  
  <html:option value="0-15">0-15</html:option> <html:option value="15-20" >15-20</html:option> <html:option value="20-30" >20-30</html:option> <html:option value="20 or above">30 or above</html:option>
  
  第二种:把选项放在一个Collection中(这里使用List).在实际项目中,更多的是可能数据来源于db,文件等。这种情况用得比较多。
  
  <html:options collection="AList" property="value" labelProperty="label"/>把option放在list中的过程在Action中作处理//prepare the age selector list.List ageList =new ArrayList();ageList.add(new LabelValueBean("0-15","0-15"));ageList.add(new LabelValueBean("15-20","15-20"));ageList.add(new LabelValueBean("20-30","20-30"));ageList.add(new LabelValueBean("30 or above","30 or above"));request.setAttribute("AList",AList);
  
  这里使用了LabelValueBean,可以不用的,象
  <html:options collection="AList" labelProperty="value" property="id" />
  
  只要在AList中填入的bean有value和id属性就可以
  
  第三种,把此list 作为Form 的一个属性.
  <html:optionsCollection property="AList" />
  
  在Form 中添加AList 的setter和getter. Form中作如下处理。
  //the list can be a form property.
  f.setAgeList(AList);
  
  1.从数据库中获得数据,你应该在Action里面取得数据后,将数据放到Request里面
  
  2.数据取出来后放在一个List或Collection或Map里面,我习惯用List
  
  3.从List或其它的容器中取数据应该用<html:options> 或<html:optionsCollection>
  
  4.<html:options> 和<html:optionsCollection>外层必须用<html:select property="">,所以这个属性你必须在FormBean里定义
  
  5.由于你要用到这些标签,所以你必须定义FormBean
  
  6.从Action取数据,以List为例
  
  List list = xxxxx;//从数据库中取得下拉列表中的数据
  request.setAttribute("list",list);
  
  在页面显示
  
  <html:form action="xxxx">...<html:select property="xxx"><html:options collection="list" labelProperty="下拉框中显示的内容,一般是name或其它相似属性" property="各选项对应的值,一般是id" /></html:select>...</html:form>
  
  补充一点点:
  
  因为数据你要从 数据库去取, 所以一般在 action 里调用 DAO ,作为 request 的一个属性传到页面上; 这时一般用 <html:options .../> 标签
  
  另外,如果数据不从数据库去取,而是代码固定的,则一般把这种放到 ActionForm 里,作为属性在页面上取,这时一般用 <html:optionsCollection ... />

百度大联盟认证黄金会员Copyright© 1997- CNET Networks 版权所有。 ZDNet 是CNET Networks公司注册服务商标。
中华人民共和国电信与信息服务业务经营许可证编号:京ICP证010391号 京ICP备09041801号-159
京公网安备:1101082134