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

 

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

作者:诚心  来源:www.admin21.com  发布时间:2007-7-18 14:38:43 <script language="JavaScript" type="text/javascript"> </script>

减小字体 增大字体

总结一下关于web上使用下拉框的情况
从数据库中获得数据List,将数据放到Request里面使用setAttribute”AList”,AList
A
中有2个属性(String id,String value
1.
使用JSTLforEach方式

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

// 表示AList装载是许多对象,对象有两个属性:idvalueid是下拉框选项的值,value是下拉框选项在页面中显示的标识。
</html:select>
  查一下strutsapi文档,可以看到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中填入的beanvalueid属性就可以
  第三种,把此list 作为Form 的一个属性.

<html:optionsCollection property="AList" />
//
采用html:optionsCollection,要求将AList作为form的一个属性,用(new LabelValueBean封装下。
  在Form 中添加AList settergetter. Form中作如下处理。

//the list can be a form property.
f.setAgeList(AList);
  1.从数据库中获得数据,你应该在Action里面取得数据后,将数据放到Request里面
  2.数据取出来后放在一个ListCollectionMap里面,我习惯用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>


总结:<html:options .../><html:optionsCollection ... />的区别

因为数据你要从数据库去取, 所以一般在 action 里调用 DAO ,作为 request 的一个属性传到页面上; 这时一般用 <html:options .../> 标签
另外,如果数据不从数据库去取,而是代码固定的,则一般把这种放到 ActionForm 里,作为属性在页面上取,这时一般用 <html:optionsCollection ... />

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值