我有关于表单的数据,我想绑定到组合框。组合框需要始终显示相同的对象,并且绑定到对象的不同属性,但其中一个仅显示所有可能对象的子集。
我的对象可以描述为:
{"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不会诉诸于处理当前所选项目的更改)。
答案 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; }
}
您可以创建复杂的查询,并虚拟选择您想要的任何内容。