asp.net – 从通用列表中将ListItem添加到DropDownList

前端之家收集整理的这篇文章主要介绍了asp.net – 从通用列表中将ListItem添加到DropDownList前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个这个aspx代码:(sample)
<asp:DropDownList runat="server" ID="ddList1"></asp:DropDownList>

使用此代码

List<System.Web.UI.WebControls.ListItem> colors = new List<System.Web.UI.WebControls.ListItem>();
colors.Add(new ListItem("Select Value","0"));
colors.Add(new ListItem("Red","1"));
colors.Add(new ListItem("Green","2"));
colors.Add(new ListItem("Blue","3"));
ddList1.DataSource = colors;
ddList1.DataBind();

输出如下所示:

<select name="ddList1" id="ddList1">
    <option value="Select Value">Select Value</option>
    <option value="Red">Red</option>
    <option value="Green">Green</option>
    <option value="Blue">Blue</option>
</select>

我的问题是:为什么我的值(数字)消失,文本用作值AND文本?我知道如果我使用ddList1.Items.Add(New ListItem(“text”,“value”))方法,它可以工作,但是由于其他原因我需要使用通用列表作为数据源.

解决方法

因为DataBind方法仅在DataValueField属性设置时才绑定值.如果在调用DataBind之前将DataValueField属性设置为“Value”,您的值将显示标记上.

更新:您还需要将DataTextField属性设置为“文本”.这是因为手动的数据绑定和添加项不能以同样的方式工作.数据绑定不知道类型ListItem的存在,并通过评估数据源中的项目生成标记.

猜你在找的asp.Net相关文章