填充列表框的方法
本文关键字:方法 列表 填充 | 更新日期: 2023-09-27 18:19:12
我试图在一个方法上填充一个列表框。我想这样做,因为我会在我的应用中多次使用这个方法。
它是这样工作的:
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"保持空…
我做错了什么?
当您创建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
控件的所有对象
你给listBox的值成员tabella+ID,在你的查询中没有tabella字段。如您所知,值成员必须是唯一的。由于这个原因,前面的代码可以工作