加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

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

发布时间:2020-12-15 19:26:20 所属栏目:asp.Net 来源:网络整理
导读:我有一个这个aspx代码:(sample) asp:DropDownList runat="server" ID="ddList1"/asp:DropDownList 使用此代码: ListSystem.Web.UI.WebControls.ListItem colors = new ListSystem.Web.UI.WebControls.ListItem();colors.Add(new ListItem("Select Value","
我有一个这个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的存在,并通过评估数据源中的项目生成标记.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读