我尝试使用BindingList作为数据源过滤BindingSource。我尝试过BindingSource.Filter =' Text Condition'但它没有工作,没有任何反应,屏幕上的数据保持不变。但是如果我使用DataSet作为数据源它可以工作。是否可以使用BindingSource.Filter属性过滤对象列表?
我有以下课程:
class Person
{
public String Nombre { get; set; }
public String Apellido { get; set; }
public int DNI { get; set; }
public int Edad { get; set; }
public Decimal Tamano { get; set; }
}
这就是我使用它的方式:
BindingList<Person> personas = new BindingList<Person> {
new Person{ Apellido = "App1", DNI = 3011, Edad = 20, Nombre ="Name1", Tamano = new decimal(1.7)}
,new Person{ Apellido = "App2", DNI = 1520, Edad = 30, Nombre ="Name2", Tamano = new decimal(1.5)}
,new Person{ Apellido = "App3", DNI = 5654, Edad = 21, Nombre ="Name3", Tamano = new decimal(1.6)}
,new Person{ Apellido = "App4", DNI = 778, Edad = 40, Nombre ="Name4", Tamano = new decimal(1.68)}
};
BindingSource bs = new BindingSource();
bs.DataSource = personas;
grid.DataSource = bs;
bs.Filter = "Apellido like 'App1'";
这只是一个例子,它的目的是测试是否可以过滤这样的数据源。我将在新项目中使用这些知识。
pd:如果有可能,我们的想法是能够使用BindingSource.Filter。
答案 0 :(得分:8)
根据http://msdn.microsoft.com/en-us/library/system.windows.forms.bindingsource.filter.aspx
只有实现
IBindingListView
接口的基础列表才支持过滤。
BindingList<T>
似乎没有实施IBindingListView
- 因为它是基础列表,您的收藏品不会被过滤。
BindingSource类虽然不是通用的,但确实实现了这个接口,所以尝试使用它作为你的角色集合。我觉得简单地将新的BindingSource的数据源分配给BindingList是不够的,因为它不会改变底层列表。尝试:
BindingSource personas = new BindingSource { new Person{ ... }, ... };
答案 1 :(得分:3)
作为实现IBindingListView的替代方法,您可以尝试这种类型的过滤:
BindingList<Person> personas = new BindingList<Person> {
new Person{ Apellido = "App1", DNI = 3011, Edad = 20, Nombre ="Name1", Tamano = new decimal(1.7)}
,new Person{ Apellido = "App2", DNI = 1520, Edad = 30, Nombre ="Name2", Tamano = new decimal(1.5)}
,new Person{ Apellido = "App3", DNI = 5654, Edad = 21, Nombre ="Name3", Tamano = new decimal(1.6)}
,new Person{ Apellido = "App4", DNI = 778, Edad = 40, Nombre ="Name4", Tamano = new decimal(1.68)}
};
BindingList<Person> filtered = new BindingList<Person>(personas.Where(
p => p.Apellido.Contains("App1")).ToList());
grid.DataSource = filtered;
答案 2 :(得分:1)
我认为这是因为BindingSource不知道它正在过滤哪种类型的数据。将数据转换为数据集到列和行后,就可以运行过滤器。因为您的数据源是一个类,所以它无法进行自动过滤。