listbox web 控件和dropdownlist web 控件的功能几乎是一样,只是listbox web 控件是一次将所有的选项都显示出来。其使用语法如下:
<asp:listbox
id="被程序代码所控制的名称"
runat="server"
autopostback="true | false"
*datasource="<%数据系结叙述%>"
*datatextfield="数据源的字段"
*datavaluefield="数据源的字段"
rows="一次要显示的列数"
selectionmode="single | multiple"
onselectedindexchanged="事件程序名称"
>
<asp:listitem/>
</asp:listbox>
*关于和数据源的数据系结部分,我们在后面的章节再介绍。下表为listbox web 控件的常用属性:

下列范例是基本的listbox 控件用法,使用者只能单选listbox web 控件中的项目:
<html>
<form id="form1" runat="server">
请选择您喜欢的月份(单选):<br>
<asp:listbox id="listbox1" runat="server">
<asp:listitem>1 月</asp:listitem>
<asp:listitem>2 月</asp:listitem>
<asp:listitem>3 月</asp:listitem>
<asp:listitem>4 月</asp:listitem>
<asp:listitem>5 月</asp:listitem>
<asp:listitem>6 月</asp:listitem>
<asp:listitem>7 月</asp:listitem>
<asp:listitem>8 月</asp:listitem>
<asp:listitem>9 月</asp:listitem>
<asp:listitem>10 月</asp:listitem>
<asp:listitem>11 月</asp:listitem>
<asp:listitem>12 月</asp:listitem>
</asp:listbox>
</form>
</html>

listbox web 控件可以进行复选,只要将selectionmode 属性指定为multiple(复选)即可。下列范例在使用者复选完毕按下确定按钮后,将使用者所选择的项目列出:
<html>
<form id="form1" runat="server">
请选择您喜欢的月份(复选):<br>
<asp:listbox id="listbox1" selectionmode="multiple" runat="server">
<asp:listitem>1 月</asp:listitem>
<asp:listitem>2 月</asp:listitem>
<asp:listitem>3 月</asp:listitem>
<asp:listitem>4 月</asp:listitem>
<asp:listitem>5 月</asp:listitem>
<asp:listitem>6 月</asp:listitem>
<asp:listitem>7 月</asp:listitem>
<asp:listitem>8 月</asp:listitem>
<asp:listitem>9 月</asp:listitem>
<asp:listitem>10 月</asp:listitem>
<asp:listitem>11 月</asp:listitem>
<asp:listitem>12 月</asp:listitem>
</asp:listbox>
<asp:button id="btna" text="确定" onclick="btna_click"
runat="server"/><br>
<asp:label id="label1" runat="server"/>
</form>
<script language="vb" runat="server">
sub btna_click(sender as object,e as eventargs)
dim shti as short
label1.text="您喜欢的月份是: "
for shti=0 to listbox1.items.count-1
if listbox1.items(shti).selected=true then
label1.text & = listbox1.items(shti).text & " "
end if
next
end sub
</script>
</html>

listbox web 控件的事件和dropdownlist web 控件一样,只要将autopostback 属性设为true,再指定事件selectedindexchanged 所要执行的事件程序即可。下列程序代码范例中,只要使用者选择不同的选项便触发selectedindexchanged 事件:
请选择您喜欢的月份(单选):<br>
<asp:listbox id="listbox1" autopostback="true"
onselectedindexchanged ="listbox1_chg" runat="server">
<asp:listitem>1 月</asp:listitem>
<asp:listitem>2 月</asp:listitem>
<asp:listitem>3 月</asp:listitem>
<asp:listitem>4 月</asp:listitem>
<asp:listitem>5 月</asp:listitem>
<asp:listitem>6 月</asp:listitem>
<asp:listitem>7 月</asp:listitem>
<asp:listitem>8 月</asp:listitem>
<asp:listitem>9 月</asp:listitem>
<asp:listitem>10 月</asp:listitem>
<asp:listitem>11 月</asp:listitem>
<asp:listitem>12 月</asp:listitem>
</asp:listbox><br>
<asp:label id="label1" runat="server"/>
</form>
<script language="vb" runat="server">
sub listbox1_chg(sender as object,e as eventargs)
label1.text="您喜欢的月份是: " & listbox1.selecteditem.text
end sub
</script>
</html>