WPF 学生成绩管理工具开发笔记(5)—DataGrid视图过滤

        

       为实现绑定数据的表格控件实现可筛选显示,利用派生自ItemsControl控件,绑定集合会建立ICollectView视图的特性,通过构造过滤器类,实现表格根据左侧TreeView选项变化,进行过滤显示。

一、DataGrid绑定数据

  为显示成绩列表,在继承自 INotifyPropertyChanged的 ViewModel类中设置了属性Stulist,表示包含有学生各科成绩的数据 集合

private ObservableCollection<StudentSCore> _Stulist = new ObservableCollection<StudentSCore>();
public ObservableCollection<StudentSCore> Stulist
{
    get { return this._Stulist; }
    set
    {
        this._Stulist = value;
        RaisePropertyChanged(() => Stulist);
    }
}

      Xaml窗口中,将Stulist绑定到DataGrid的ItemsSource属性上。

<DataGrid x:Name="reoGrid" Grid.Row="1" Grid.Column="1" Grid.ColumnSpan="2"  
          VirtualizingPanel.VirtualizationMode="Recycling"
          VirtualizingPanel.IsVirtualizing="True" 
          ItemsSource="{Binding Stulist}"  CanUserAddRows="False"
          CellStyle="{DynamicResource DataGridCellStyle1}"
          ColumnHeaderStyle="{DynamicResource DataGridColumnHeaderStyle1}" />

二、建立过滤器

   主要是建立过滤属性和实现过滤的方法

public class StuFilter
{
    public string FilterCharacter { get; set; }
    public StuFilter(string filterWord)
    {
        FilterCharacter = filterWord;
    }

    public bool FilterItemByClass(object item)
    {
        StudentSCore stuItem = item as StudentSCore;
        if (stuItem != null)
            if (stuItem.班级== FilterCharacter)
                return true;
        return false;
    }
    public bool FilterItemByName(object item)
    {
        StudentSCore stuItem = item as StudentSCore;
        if (stuItem != null)
            if (stuItem.姓名 == FilterCharacter)
                return true;
        return false;
    }

三、视图实现

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值