web中下拉列表的几种实现

转载 2006年06月23日 02:19:00

从数据库中获得数据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 ... />

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

带时间的日期选择web控件

1,web控件的样子 2,日期时间选择的使用 3,calendar.js的文件 ...
  • daditao
  • daditao
  • 2013年12月10日 11:12
  • 13075

jsp页面中的下拉列表

在WEB开发过程中,我们经常遇到信息修改的功能需求。这时我们给用户提供一个JSP页面,展示出当前的信息并允许用户重新设置新值。而在这个页面中,一般是少不了下拉列表的。至于它的处理方式,我以前想过一种,...

Web前端开发实战1:二级下拉式菜单之CSS实现

二级下拉式菜单在各大学校网站,电商类网站,新闻类网站等大型?网站很常见,那么它的实现原理是什么呢? 学习了Web前端开发的知识后,我们是可以实现这样的功能的。复杂的都是从基础效果上添加做出来的,原理和...

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

Ajax调用后台action返回JSONArray(JSONObject)类型实现jsp中下拉列表的动态显示

1、jsp页面的一个onchange或者onclick事件调用js中的一个方法,该方法使用Ajax技术动态调用数据库中的数据,并且异步写回一个JSONArray,根据select中的option属性显...

ALV中下拉列表列的实现

有时候我们可以把一些字段设置为下拉,比如一些类型,一些字段的值是比较固定的一些值,如性别等。设置为下拉,和设置超级链接是类似的,也是使用了一个内表存放了句柄和对应的值,这个表类型为”LVC_T_DRO...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:web中下拉列表的几种实现
举报原因:
原因补充:

(最多只允许输入30个字)