Dropdownlist Datasource and adding extra item from C#

34,310

Solution 1

It's most probably because you're adding the item before the DataBind(). If you want to add an item with

ddlVisualTemplate.Items.Add()

then you have to do it after the dropdown is being bound.

If you look at http://msdn.microsoft.com/en-us/library/ms178472.aspx then DataBind is being done in PreRenderComplete. So you have to add the element in some event that occurs after PreRenderComplete. Or you could do it on the ddlVisualTemplate.DataBound event.

Solution 2

Probably too late for the original poster, but maybe useful for other users:

You can add the value "None", "Choose value", etc. in the designer (or in the code) and prevent DataBind from overwriting it, by setting AppendDataBoundItems="true". This will make DataBind append rather than clear.

Below example from Scott Guthrie's post ListControl.AppendDataBoundItems Property in ASP.NET 2.0.

<asp:DropDownList ID="DropDownList1" AppendDataBoundItems="true" runat="server" DataSourceID="SqlDataSource1" DataTextField="state" DataValueField="state">    
    <asp:ListItem Text="(Select a State)" Value="" />   
</asp:DropDownList>
<asp:SqlDataSource ID="SqlDataSource1" runat="server"
                   ConnectionString="<%$ ConnectionStrings:pubsConnectionString %>"
                   SelectCommand="SELECT DISTINCT [state] FROM [authors]">
</asp:SqlDataSource>

Solution 3

You could easily fix this by setting the datasource prgrammatically:

ddlVisualTemplate.DataSource = VisualTemplateDataSource;
ddlVisualTemplate.DataBind();

ddlVisualTemplate.Items.Add(new ListItem("None", string.Empty));

BTW, these datasource controls are a wrong thing in asp.net in my opinion. I don't like the idea of defining the data source and giving the control over db connections to the aspx page. For a better way of doing this just google about session per request pattern, separation of concerns and n-tier apps.

Update: instead of "VisualTemplateDataSource" you could call directly the data. I don't know EF, but it might be like this: "DataContext.tbEmailVisualTemplates". You have to set your datacontext. And then you can get rid of the datasource control.

Solution 4

Use this to add an item in the bound dropdown list at 0 index

ddlTicketType.Items.Insert(0, new ListItem("All", "0"));
Share:
34,310
Sami
Author by

Sami

Updated on August 04, 2020

Comments

  • Sami
    Sami almost 4 years

    I have a DropDownList that is associated with a DataSource in the aspx page. I need to add one more item when the page is loaded.

    My Code:

    <asp:LabelDropDownList ID="ddlVisualTemplate" runat="server" LabelText="Visual Template:"      DataSourceID="VisualTemplateDataSource" DataTextField="Name" DataValueField="Id" AutoPostBack="true" OnSelectedIndexChanged="ddlVisualTemplate_SelectedIndexChanged"/>                         
    
    <asp:EntityDataSource ID="VisualTemplateDataSource" runat="server" 
         ConnectionString="name=Entities" 
         DefaultContainerName="Entities" EnableFlattening="False" 
         EntitySetName="tbEmailVisualTemplates">
    

    And I am trying to an extra item to it:

        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                ddlVisualTemplate.Items.Add(new ListItem("None", string.Empty));
            }
        }
    

    If I debug the code, it goes through it. But When the page is displayed dropdown doesn't contain "None".

  • Sami
    Sami almost 13 years
    Thanks! That is what exactly I was looking for.
  • MoMo
    MoMo almost 11 years
    ddlTest.Items.Insert(0, new ListItem("All", string.Empty)); Will put the item at the top