我在ASP.NET页面上有一个由SQL数据库填充的DropDownList。
<asp:DropDownList ID="ddlName" runat="server"></asp:DropDownList>
人口在文件背后的代码中显示:
ddlName.DataSource = SqlDataSource1;
ddlName.DataValueField = (this.ddlName.SelectedValue);
ddlName.DataTextField = "ccName";
ddlName.DataBind();
我想知道是否可以根据它的值更改列表中项目的背景或文本颜色?
我刚刚注意到,下面的示例在页面首次加载时起作用但在回发时文本颜色消失,即使这是代码所在的位置。有什么我想念的吗?
protected override void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
ddlName.DataSource = SqlDataSource5;
ddlName.DataValueField = (this.ddlName.SelectedValue);
ddlName.DataTextField = "ccName";
ddlName.DataBind();
foreach (ListItem item in ddlName.Items)
{
if (item.Value == "Item 1")
{
item.Attributes.Add("style", "color:red");
}
if (item.Value == "Item 2")
{
item.Attributes.Add("style", "color:red");
}
}
}
}
答案 0 :(得分:5)
你确定可以,将其添加到你的页面加载事件中。
foreach(ListItem item in ddlName.Items) {
if(item.Value == "someStringValue") {
item.Attributes.Add("style", "color:red")
}
}
如果这不起作用,您可以将此代码移动到下拉列表的DataBound事件。