3

我有一个我认为是一个简单的问题,但经过大量搜索后找不到合适的例子。简而言之,它是一个 Windows 窗体应用程序,在窗体上有 2 个数据绑定组合框,第一个用于“部门”,第二个用于“部门”。这些组合每个都绑定到 SQL 数据库中的相应表。组合应该与用户从第一个选择部门一起操作,这会导致第二个组合被过滤以仅显示属于该部门的部分。(换句话说,这是经典的“级联”组合框问题)。我的经验最初是使用 Delphi,这是一个简单的设计时问题。

但是,在 C# 中,我被卡住了,无法让它工作。我原以为这可以在设计时通过 SelectedIndexChanged 事件背后的一些最少代码来完成。如果有人有一个基本的(表单、2个组合框、简单的数据源)示例,我将不胜感激。

谢谢,詹姆斯

4

2 回答 2

1
ComboBox cbDepartment = new ComboBox();
cbDepartment.Name = "cbDepartment";
cbDepartment.DataSource = dsDepartments;
cbDepartment.SelectedIndexChanged = new System.EventHandler(cbDepartment_SelectedIndexChanged);

private void cbDepartment_SelectedIndexChanged(object sender, System.EventArgs e) {
    cbSection.DataSource = GetSection(cbDepartment.SelectedItem.Value);
}

你可以试试上面的方法。

于 2011-07-27T20:50:03.740 回答
0

您没有指定要绑定的内容。我总是绑定到对象,所以我是这样做的:

在表单加载事件中:

ddlParent.DataSource = new BindingSource(myIEnumerable, null);

以及父组合框的事件处理程序:

private void ddlParent_SelectedIndexChanged(object sender, EventArgs e)
{
    ddlChild.DataSource = new BindingSource((MyBoundType)ddlParent.SelectedItem, null);
}

我不知道在设计时有什么办法。

您可能应该重写绑定到下拉列表的对象的 ToString() 方法,以控制组合框中显示的文本。

于 2011-07-27T20:51:07.843 回答