2008-11-10 93 views

回答

9

以下是如何在列表顶部添加值的方法。它可以是一个空字符串或一些文本。

<asp:DropDownList ID="categories" runat="server" AppendDataBoundItems="True" AutoPostBack="True" DataSourceID="categoriesDataSource" DataTextField="CategoryName" DataValueField="CategoryID" EnableViewState="False"> 
    <asp:ListItem Value="-1"> 
     -- Choose a Category -- 
    </asp:ListItem>   
</asp:DropDownList> 

一定要设置DropDownList的AppendDataBoundItems = True。

+0

你为什么不这项建议添加到您的示例代码清晰? – Keltex 2008-11-10 16:21:10

0

我提供IEnumerable<string>扩展方法,追加的项目列表的开头:

public static IEnumerable<string> Prepend(this IEnumerable<string> data, string item) 
    { 
     return new string[] { item == null ? string.Empty : item }.Union(data); 
    } 

及其分类LINQ-Y的,因为它使用LINQ扩展方法联盟。它干净了一点比这样做:

var result = new string[]{string.Empty}.Union(from x in data select x.ToString()); 
1

标记:

<asp:DropDownList ID="ddlQualQuestion" runat="server" DataSourceID="sdsQualQuestion" DataTextField="ShortQuestionText" DataValueField="QualificationQuestionKey" AutoPostBack="true" OnSelectedIndexChanged="ddlQualQuestion_SelectedIndexChanged" OnDataBound="ddlQualQuestion_DataBound" />; 

后面的代码:

protected void ddlQualQuestion_DataBound(object sender, EventArgs e) 
{ 
    ddlQualQuestion.Items.Insert(0, new ListItem("", "0")); 
} 
1

以DOK提供的解决方案:

<asp:DropDownList ID="categories" runat="server" AppendDataBoundItems="True" AutoPostBack="True" DataSourceID="categoriesDataSource" DataTextField="CategoryName" DataValueField="CategoryID" EnableViewState="False"> 
    <asp:ListItem Value="-1"> 
     -- Choose a Category -- 
    </asp:ListItem>   
</asp:DropDownList> 

Addtionally,如果你不想强制用户做一个选择,你可以添加一个方法来你的GridView的使用LinqDataSource:

OnSelecting="myGridview_Selecting" 

添加代码的背后是这样的:

protected void myGridview_Selecting(object sender, LinqDataSourceSelectEventArgs e) 
{ 
    if (categories.SelectedValue == "-1") 
    { 
     e.WhereParameters.Remove("CategoryID"); 
    } 
}