如何同时绑定到列表和子列表?

时间:2013-04-22 11:59:19

标签: c# winforms data-binding

我有关于表单的数据,我想绑定到组合框。组合框需要始终显示相同的对象,并且绑定到对象的不同属性,但其中一个仅显示所有可能对象的子集。

我的对象可以描述为:

{"q",#1,1},{"w",#1,2},{"e",#1,3},{"r",#2,6},{"t",#3,2},{"y",#3,6} etc

第一个组合框显示第一个字段和完整列表,确切地说:

"q","w","e","r","t","y" etc

第二个组合框显示第三个字段,但仅适用于具有与当前所选对象相似的第二个字段的对象。

如果选择{“q”,#1,1},则显示:

1,2,3

如果选择{“r”,#2,6},则显示:

6

在任何组合框中选择其他项目会更改当前所选项目(并相应地更新其他组合框)。

使用winforms数据绑定执行此操作的最优雅或“正确”方法是什么? (对我来说,elegat不会诉诸于处理当前所选项目的更改)。

2 个答案:

答案 0 :(得分:1)

这可能会有所帮助:

List<Tuple<string, string, int>> values = new List<Tuple<string, string, int>>();

然后:

comboBox1.DisplayMember = "Item1";
comboBox1.DataSource = values;

comboBox2.DisplayMember = "Item3";

var filter = ((Tuple<string, string, int>)comboBox1.SelectedItem).Item2;

comboBox2.DataSource = values.Where(input => input.Item2 == filter);

答案 1 :(得分:0)

为要绑定的每个ComboBox创建一个属性。现在,属性实际上可以是LINQ表达式,为您过滤正确的数据。

此类属性的示例:

private final List<MyObj> _allObjects = new List<MyObj>();
... // fill the _allObjects somewhere


public IEnumerable<MyObj> AllGoodObjects 
{
    get { return from o in _allObjects 
                 where o.IsGood
                 select o; }
}

public IEnumerable<MyObj> AllBadObjects 
{
    get { return from o in _allObjects 
                 where !o.IsGood
                 select o; }
}

您可以创建复杂的查询,并虚拟选择您想要的任何内容。