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

本文介绍如何使用DataGrid控件结合自定义过滤器实现成绩列表的动态筛选显示。通过在ViewModel中设置包含学生成绩的ObservableCollection,并在XAML中将其绑定到DataGrid的ItemsSource属性上,实现了基本的数据展示。进一步,通过创建StuFilter类,实现根据班级或姓名的过滤条件,动态更新DataGrid显示的内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        

       为实现绑定数据的表格控件实现可筛选显示,利用派生自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;
    }

三、视图实现

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值