您的绑定代码不完整。试试这个:
BindingSource bsCustomers = new BindingSource();
bsCustomers.DataSource = _customers;
comboBox.DataBindings.Add(
new System.Windows.Forms.Binding("SelectedValue", bsCustomers, "id", true));
comboBox.DataSource = bsCustomers;
comboBox.DisplayMember = "name";
comboBox.ValueMember = "id";
在大多数情况下,您可以在设计器中完成此任务,而不是在代码中完成。
首先在 Visual Studio 的“数据源”窗口中添加数据源。从菜单View > Other Windows > Data Sources打开它。添加一个 Object 类型的数据源Customer
。在数据源中,您将看到客户的属性。通过右键单击属性,您可以更改与其关联的默认控件。
现在您可以简单地将属性从 Data Sources 窗口拖到您的表单中。当您删除第一个控件时,Visual Studio 会自动将 ABindingSource
和一个组件添加到您的表单中。BindingNavigator
这BindingNavigator
是可选的,如果您不需要它,您可以安全地删除它。Visual Studio 也完成了所有的连接。您可以通过属性窗口对其进行调整。有时这对于组合框是必需的。
在您的代码中只剩下一件事要做:将实际数据源分配给绑定源:
customerBindingSource.DataSource = _customers;