日期:2014-05-17  浏览次数:20715 次

请教一个JSP下拉列表问题
这是一个获取下拉列表项的方法,能够输出所有的列表项,但在jsp页面时却只能显示最后一项
public List<Type> loadPetsType() throws Exception
{
List<Type> list = null;
sql = "SELECT ID, TYPENAME FROM Type ";
try
{
this.pst = this.conn.prepareStatement(sql);
ResultSet rs = this.pst.executeQuery();
while (rs.next())
{
list = new ArrayList<Type>();
type = new Type();
type.setTypeId(rs.getInt(1));
System.out.println(type.getTypeId() + " ");
type.setTypeName(rs.getString(2));
System.out.println(type.getTypeName() + " ");
list.add(type);
}
} catch (Exception e)
{
throw e;
} finally
{
if (this.pst != null)
{
try
{
this.pst.close();
} catch (Exception e)
{
throw e;
}
}
}
return list;
}

jsp页面代码:
<select name="select" class="Common">
<%
List<Type> list = null;
try
{
list = DAOFactory.getIPetsDAOInstance().loadPetsType();
request.setAttribute("typeList", list);
%>
<c:forEach items="${typeList}" var="type">
<option value="${type.typeId}">
${type.typeName }
</option>
</c:forEach>
<%
} catch (Exception e)
{
e.printStackTrace();
}
%>
</select>
请问这是怎么回事?
输出如下:

宠物小狗  

宠物小猪  

宠物小猫  

宠物兔  

宠物鼠  

宠物猴  

宠物蛇  
16 
宠物 
jsp页面只显示16 宠物

------解决方案--------------------
list = new ArrayList<Type>();放到while外面去。
------解决方案--------------------
list = new ArrayList<Type>(); 你每次都生成一个新的列表。
------解决方案--------------------
问题的根源是,你初始化是在while循环内,每一次循环都初始化一次,list存放的是最后一次循环的一条记录(也就是最后一条记录)
解决方法:就是3楼的方法,list初始化在while循环之前。
------解决方案--------------------
每次你都重新NEW了一个LIST...也就是它 list = new ArrayList<Type>();


放在while上面。。
------解决方案--------------------
+++++++++++++++++++++ 1
探讨

每次你都重新NEW了一个LIST...也就是它 list = new ArrayList<Type>();


放在while上面。。

------解决方案--------------------
List<Type> list = new ArrayList<Type>();
sql = "SELECT ID, TYPENAME FROM Type ";
try
{
this.pst = this.conn.prepareStatement(sql);
ResultSet rs = this.pst.executeQuery();
while (rs.next())
{
.....................