我试图通过方法填充列表框。我想这样做,因为我会在我的应用程序中多次使用此方法。
以下是它的工作方式:
DataTable table = ru.getDataTable("Select UserID, User From tblUser Where tblUser.Archived = false");
lstBenutzer.DataSource = table;
lstBenutzer.ValueMember = "UserID";
lstBenutzer.DisplayMember = "User";
我想这样做:
lstBenutzer = getListbox("Select UserID, User From tblUser Where tblUser.Archived = false", "User");
private ListBox getListbox(string query, string tabelle)
{
ListBox box = new ListBox();
DataTable table = ru.getDataTable(query);
box.DataSource = table;
box.ValueMember = tabelle + "ID";
box.DisplayMember = tabelle;
return box;
}
我没有得到任何错误,它只是不起作用。 我的列表框" lstBenutzer"保持空虚......
我做错了什么?
答案 0 :(得分:2)
当您创建ListBox
控件的新实例时,它将替换您在设计视图中创建的生成控件。您可以将ListBox
控件的整个对象传递给您的方法,而不是创建新实例。
private void getListbox(ListBox listBox, string query, string tabelle)
{
DataTable table = ru.getDataTable(query);
listBox.DataSource = table;
listBox.ValueMember = tabelle + "ID";
listBox.DisplayMember = tabelle;
}
你可以这样称呼它:
getListbox(lstBenutzer, "Select UserID, User From tblUser Where tblUser.Archived = false", "User");
您还可以使用扩展方法使其在ListBox
控件类型
答案 1 :(得分:0)
你给了listBox的值成员tabella + ID,在你的查询中没有tabella字段。如您所知,值成员必须是唯一的。出于这个原因,以前的代码工作