填充列表框的方法

本文关键字:方法 列表 填充 | 更新日期: 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字段。如您所知,值成员必须是唯一的。由于这个原因,前面的代码可以工作