1

如何在DisplayMember不更改的情况下在末尾添加一些文本或其他字段DataSource

this.lstSubjects.DataSource = this.subjectBindingSource;
this.lstSubjects.DisplayMember = "Caption";
this.lstSubjects.FormattingEnabled = true;
this.lstSubjects.Name = "lstSubjects";
this.lstSubjects.ValueMember = "SubjectCode";
this.lstSubjects.SelectedIndexChanged += new System.EventHandler(this.lstSubjects_SelectedIndexChanged);

例如,我想在每个列表框行中同时显示DataTable 的CaptionSubjectCode字段,但是每行的值将是SubjectCode

我想要这样的东西:

ListBox 的 DisplayMember = "技术 (AD)"

列表框的值 = "AD"

提前致谢,

4

2 回答 2

2

首先,您可以为 DisplayMember 保留一个属性,例如:

lstSubjects.DisplayMember = "lastname";

现在,在 [Design] 模式下转到您的表单,右键单击 ListBox -> Properties。

在属性窗口的顶部,单击事件(闪电图标),

在下面的事件列表中(在 Property Changed 下)查找 Format 并在那里输入一些事件名称,比如说: lstSubjectsFormat ,然后按 Enter。你会看到这个:

private void lstSubjectsFormat(object sender, ListControlConvertEventArgs e)
{

}

现在在里面写下以下几行:

private void lstSubjectsFormat(object sender, ListControlConvertEventArgs e)
{
    // Assuming your class called Employee , and Firstname & Lastname are the fields
    string lastname = ((Employee)e.ListItem).Firstname;
    string firstname = ((Employee)e.ListItem).Lastname;
    e.Value = lastname + " " + firstname;
}

而已 ;)

于 2013-09-15T21:25:35.277 回答
0

我有它给你。据我了解,您正在执行 sql 查询来获取您的数据。使用使您的查询包含您需要的字符串。例如,如果您的表包含两个 varchar 字段,您可以这样做

SELECT column1 +'(' + column2 + ')' FROM myTable;

这是最好的方法,也是正确的方法,我花了一些时间才找到它......

于 2013-07-24T06:00:32.720 回答