List nameList = new List();
DropDownList ddl = new DropDownList();
List is populated here, then sorted:
Replace this:
ddl.Items.Add(new ListItem(nameList[name].ToString()));
with this:
ddl.Items.Add(new ListItem(name));
Done like dinner.
That would be because List is not indexed by string (name) but by ints.
foreach (string name in nameList)
{
ddl.Items.Add(new ListItem(name));
}
Will fix that.
foreach (string name in nameList){
ddl.Items.Add(new ListItem(nameList[name].ToString()));
}
Is your problem.
it should look more like
foreach (string name in nameList){
ddl.Items.Add(new ListItem(name.ToString()));
}
But I actually like Marcus' suggestion a little better.
You get that error because the collection nameList
is a List
so you must access it using an index not a string (you use name).
So you can write:
foreach (string name in nameList){
ddl.Items.Add(name);
}
BTW the best way to do this is:
ddl.DataSource = nameList;
ddl.DataBind();
Why not just bind the DDL directly to the List like
DropDownList ddl = new DropDownList();
ddl.DataSource = nameList;
ddl.DataBind();
ddl.DataSource = nameList;
ddl.DataBind();
Doesn't work if it's a SharePoint list - Error: Data source is an invalid type. It must be either an IListSource, IEnumerable, or IDataSource. Decided to chime in, in case any SharePoint developers thought this was for an SPList instead of List<string>, as was written above.
There is a way to bind to an SPList, but you'd use an SPListItemCollection, or go one better and use an SPDataSource. For the SharePoint developers, see this blog by Chris O' Brien.