首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >填充列表盒过载法

填充列表盒过载法
EN

Stack Overflow用户
提问于 2015-10-26 11:37:32
回答 2查看 70关注 0票数 0

我正试着用一种方法来填满一个列表框。我想这样做,因为我将在我的应用程序中多次使用这个方法。

它的工作方式如下:

代码语言:javascript
复制
DataTable table = ru.getDataTable("Select UserID, User From tblUser Where tblUser.Archived = false");

            lstBenutzer.DataSource = table;
            lstBenutzer.ValueMember = "UserID";
            lstBenutzer.DisplayMember = "User";

我想这样做:

代码语言:javascript
复制
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“是空的..。

我做错什么了?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-10-26 11:55:01

当您创建ListBox控件的新实例时,它将替换在设计视图中创建的生成的控件。您可以将ListBox控件的整个对象传递给您的方法,而不是创建新实例。

代码语言:javascript
复制
private void getListbox(ListBox listBox, string query, string tabelle)
{
            DataTable table = ru.getDataTable(query);

            listBox.DataSource = table;
            listBox.ValueMember = tabelle + "ID";
            listBox.DisplayMember = tabelle;
}

你可以这样称呼它:

代码语言:javascript
复制
getListbox(lstBenutzer, "Select UserID, User From tblUser Where tblUser.Archived = false", "User");

还可以使用扩展方法使其在ListBox控件类型的所有对象上可用。

票数 2
EN

Stack Overflow用户

发布于 2015-10-26 12:34:20

您给了listBox的值成员tabella+ID,在查询中没有这样的tabella字段。如您所知,值成员必须是唯一的。由于这个原因,以前的代码可以工作。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33344813

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档