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

作者:网络 来源:佚名 更新时间:2008-02-08 点击:

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

从数据库中获得数据list,将数据放到request里面使用setattribute(”alist”,alist)

a中有2个属性(string id,string value)

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 ... />

最大的网站源码资源下载站,