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

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

使用此代码

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

输出如下所示:

  1. <select name="ddList1" id="ddList1">
  2. <option value="Select Value">Select Value</option>
  3. <option value="Red">Red</option>
  4. <option value="Green">Green</option>
  5. <option value="Blue">Blue</option>
  6. </select>

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

解决方法

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

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

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