[英]How can I bind an Entity Framework association to a ComboBox?
我正在开发一个内部软件跟踪程序,每个程序修订版都从员工数据库中分配了一个首席程序员。 到目前为止,我的简单 model 看起来像这样:
最初我有一个RevisionBindingSource
object 绑定到我的Revisions
集合:
Dim container as new EntityContainer
revisionBindingSource.DataSource = container.Revisions
...
dgRevisions.DataSource = revisionBindingSource
dgRevisions.DataMemeber = ""
这很好用,我能够绑定到我需要的各种属性,例如应用程序标题:
lblAppTitle.DataBindings.Add("Text",revisionBindingSource,"Application.Title")
但是,我现在需要一个 ComboBox,其项目绑定到员工列表,其选定值绑定到当前版本的首席程序员。 我尝试创建一个新的employeeBindingSource
,但意识到我没有Value
的绑定成员:
employeeBindingSource.DataSource = container.Employees
...
cboLead.DataSource = employeeBindingSource
cboLead.DisplayMember = "Name.Display" 'Name is a complex type'
cboLead.ValueMember = '??
所以我重写了一些绑定,使其只有一个bindingSource
:
bindingSource.DataSource = container
...
dgRevisions.DataSource = bindingSource
dgRevisions.DataMemeber = "Revisions"
...
cboLead.DataSource = bindingSource
cboLead.DisplayMember = "Employees.Name.Display"
cboLead.ValueMember = "Employees"
...
lblAppTitle.DataBindings.Add("Text",bindingSource,"Revisions.Application.Title")
这仍然没有用任何东西填充 ComboBox。
哪种模式更适合我使用 - 两个不同的绑定源,还是一个? 我在绑定我的 ComboBox 时做错了什么? 一旦我的 ComboBox 填充,我如何将当前值绑定到修订版的首席程序员?
对不起,冗长的问题,谢谢。
在您的表单上拥有多个绑定源并没有错。 实际上,像您上面建议的那样“链接”绑定源可能是一种方便的策略。
但是,在这种情况下,您需要填写一个缺失的链接以支持将.Value
属性绑定到实际的 EF object:您需要创建一个单独的 class 以进行绑定。 此技术在绑定到枚举时也非常有用。
当您的 EF 数据 model 与您希望 UI 的工作方式不完全匹配时,此技术非常常见。 对于 WPF(不是本示例中的 WinForms),这通常被称为 ViewModel 的一部分。 这样做几次后,它就会成为第二天性。
这是您需要创建的 class 的示例实现:
public class EmployeeBindingObject
{
public Employee Employee { get; private set; }
public string EmployeeName
{
get { return this.Employee.Name; }
}
private EmployeeBindingObject(Employee employee)
{
this.Employee = employee;
}
/// <summary>
/// Gets a binding list for a specified list of Employees.
/// </summary>
/// <param name="types"></param>
/// <returns></returns>
public static IBindingList GetBindingList(IEnumerable<Employee> employees)
{
BindingList<EmployeeBindingObject> result = new BindingList<EmployeeBindingObject>();
foreach (var ee in employees)
{
result.Add(new EmployeeBindingObject(ee));
}
return result;
}
}
创建此 class 后,您应该编译并为 EmployeeBindingObject 创建一个数据源(数据 -> 添加新数据源...)。
ValueMember
设置为Employee
DisplayMember
设置为EmployeeName
SelectedValue
属性设置为其他 BindingSource 的Employee
属性。然后,在您的代码中,您需要初始化绑定 object BindingSource,如下所示:
employeeBindingObjectBindingSource.DataSource = EmployeeBindingObject.GetBindingList(container.Employees)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.