• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

servlet/jsp 搞代码 7年前 (2018-06-18) 257次浏览 已收录 0个评论

总结一下关于web上使用下拉框的情况

数据库中获得数据List,将数据放到Request里面使用setAttribute(”AList”,AList)

A中有2个属性(String id,String value)

http://www.gaodaima.com/?p=44191关于web中下拉列表的几种实现方法

1.使用jsTL的forEach方式

<select name=”xx” ……..>
<c:forEach items=”${AList}” var=”p” >
<c:choose>
<c:when test=”${xxx == p.id}”>
<option value='<c:out value=”${p.id}”/>’ selected=”selected”>
<c:out value=”${p.value}”/>
</option>
</c:when>
<c:otherwise>
<option value='<c:out value=”${p.id}”/>’>
<c:out value=”${p.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 … />

欢迎大家阅读《关于web中下拉列表的几种实现方法》,跪求各位点评,若觉得好的话请收藏本文,by 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:关于web中下拉列表的几种实现方法

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址