Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Databind ASP.NET List of ListItem to DropDownList issue

I've just come across this bizarre thing that I was expecting to work in a different (logical) way, but it doesn't. Is it a bug or a "feature"?

So there's a DropDownList that I'm populating in the codebehind with a List of ListItem. Each new ListItem gets 2 arguments that, according to the intellisense-provided documentation, correspond to its text and value:

List<ListItem> users = new List<ListItem>();
foreach (SubscriptionUser su in subscriptionDetails.UserList)
{
    users.Add(new ListItem(su.FirstName + " " + su.LastName, su.EmailAddress));
}
ddlPrimaryContact.DataSource = users;
ddlPrimaryContact.DataBind();

Now, can someone explain me why the databound DropDownList both the Text and Value set to exactly the same (the ListItem text) instead of using ListItem.Text as the Text and ListItem.Value as the Value?

ARGH!! http://www.freeimagehosting.net/uploads/fe65d0e7d5.jpg

Or am I doing something wrong?

like image 463
Farinha Avatar asked Aug 12 '09 11:08

Farinha


2 Answers

Hi when databinding (to anything) you need to set the DataTextField and DataValueField of your DropDownList. In your case you should use the following code

List<ListItem> users = new List<ListItem>();
foreach (SubscriptionUser su in subscriptionDetails.UserList)
{
    users.Add(new ListItem(su.FirstName + " " + su.LastName, su.EmailAddress));
}
ddlPrimaryContact.DataTextField = "Text";
ddlPrimaryContact.DataValueField = "Value";
ddlPrimaryContact.DataSource = users;
ddlPrimaryContact.DataBind();
like image 110
Matthew Dresser Avatar answered Oct 11 '22 08:10

Matthew Dresser


You should bind your dropdown list as :

ddlPrimaryContact.DataSource = users;
ddlPrimaryContact.DataTextField = "Value";
ddlPrimaryContact.DataValueField = "Text";
ddlPrimaryContact.DataBind();

If you ask why, as far as I know, databound controls takes texts and values (if they are not supplied like above) by calling the ToString method for each item in datasource collection. So each ListItem in your collection return it's Text property by ToString method.

like image 11
Canavar Avatar answered Oct 11 '22 07:10

Canavar