在方法上填写列表框

时间:2015-10-26 11:37:32

标签: c# visual-studio methods listbox

我试图通过方法填充列表框。我想这样做,因为我会在我的应用程序中多次使用此方法。

以下是它的工作方式:

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"保持空虚......

我做错了什么?

2 个答案:

答案 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字段。如您所知,值成员必须是唯一的。出于这个原因,以前的代码工作