原文:WPF 精修篇 DataGrid 筛选

DataGrid也可以分组 但是用的地方不多 就没写

筛选还是可以的 比如Datagrid数据量比较大 要做数据筛选

贴码


  1. <DataGrid x:Name="datagrid" AutoGenerateColumns="False" HorizontalContentAlignment="Stretch" VerticalContentAlignment="Stretch">
  2. <DataGrid.Columns>
  3. <DataGridTextColumn Binding="{Binding Name}" Header="Name"></DataGridTextColumn>
  4. <DataGridTextColumn Binding="{Binding Address}" Header="Address"></DataGridTextColumn>
  5. <DataGridTextColumn Binding="{Binding Age}" Header="Age"></DataGridTextColumn>
  6. </DataGrid.Columns>
  7. </DataGrid>
  8. <CheckBox x:Name="sort" Content="排序" HorizontalAlignment="Left" Margin="466,300,0,0" VerticalAlignment="Top" Checked="CheckBox_Checked"/>
  9. <TextBox x:Name="TxT" HorizontalAlignment="Left" Height="25" Margin="402,5,0,0" TextWrapping="Wrap" VerticalAlignment="Top" Width="115" TextChanged="TextBox_TextChanged"/>
  10. <TextBlock HorizontalAlignment="Left" Height="20" Margin="336,8,0,0" TextWrapping="Wrap" Text="筛选内容" VerticalAlignment="Top" Width="61"/>
  11. </Grid>

  1. public MainWindow()
  2. {
  3. InitializeComponent();
  4. Preson = new ObservableCollection<Preson>() {
  5. new Preson() { Name = "慧哥1", Address = "大连1", Age = 31 },
  6. new Preson() { Name = "慧哥2", Address = "大连2", Age = 32 },
  7. new Preson() { Name = "慧哥3", Address = "大连3", Age = 33 },
  8. new Preson() { Name = "慧哥4", Address = "大连4", Age = 34 },
  9. new Preson() { Name = "慧哥5", Address = "大连5", Age = 35 },
  10. new Preson() { Name = "123", Address = "大连6", Age = 12 },
  11. new Preson() { Name = "444", Address = "大连7", Age = 14 },
  12. new Preson() { Name = "222", Address = "大连8", Age = 33 },
  13. new Preson() { Name = "1312", Address = "大连9", Age = 22 }
  14. };
  15. datagrid.ItemsSource = Preson;
  16. }
  17. public ObservableCollection<Preson> Preson
  18. {
  19. get { return (ObservableCollection<Preson>)GetValue(PresonProperty); }
  20. set { SetValue(PresonProperty, value); }
  21. }
  22. // Using a DependencyProperty as the backing store for Preson. This enables animation, styling, binding, etc...
  23. public static readonly DependencyProperty PresonProperty =
  24. DependencyProperty.Register("Preson", typeof(ObservableCollection<Preson>), typeof(MainWindow), new PropertyMetadata(null));
  25. private void CheckBox_Checked(object sender, RoutedEventArgs e)
  26. {
  27. var cvs = CollectionViewSource.GetDefaultView(datagrid.ItemsSource);
  28. if(cvs!=null&&cvs.CanSort)
  29. {
  30. cvs.SortDescriptions.Clear();
  31. if (sort.IsChecked == true)
  32. {
  33. cvs.SortDescriptions.Add(new System.ComponentModel.SortDescription("Age", System.ComponentModel.ListSortDirection.Descending));
  34. }
  35. }
  36. }
  37. private void TextBox_TextChanged(object sender, TextChangedEventArgs e)
  38. {
  39. var cvs = CollectionViewSource.GetDefaultView(datagrid.ItemsSource);
  40. if (cvs != null && cvs.CanFilter)
  41. {
  42. cvs.Filter = OnFilterApplied;
  43. }
  44. }
  45. private bool OnFilterApplied(object obj)
  46. {
  47. if (obj is Preson)
  48. {
  49. var text = TxT.Text.ToLower();
  50. return (obj as Preson).Name.ToLower().Contains(text)
  51. || (obj as Preson).Address.ToLower().Contains(text);
  52. }
  53. return false;
  54. }
  55. }

啊~ 这里包含排序 那就包含吧~~

WPF 精修篇 DataGrid 筛选的更多相关文章

  1. WPF 精修篇 DataGrid 数据源排序

    原文:WPF 精修篇 DataGrid 数据源排序 效果 <DataGrid x:Name="datagrid" ItemsSource="{Binding Ele ...

  2. WPF 精修篇 数据触发器

    原文:WPF 精修篇 数据触发器 数据触发器 可以使用Binding 来绑定控件 或者数据源 来触发相关动作 举栗子 <Window.Resources> <Style Target ...

  3. WPF 精修篇 属性触发器

    原文:WPF 精修篇 属性触发器 属性触发器是通过  某个条件触发改变属性 通过无代码实现功能 <Style TargetType="{x:Type Label}"> ...

  4. WPF 精修篇 样式继承

    原文:WPF 精修篇 样式继承 这个 是新知识 样式可以继承 <Style x:Key="TextBlockStyleBase" TargetType="{x:Ty ...

  5. WPF 精修篇 自定义控件

    原文:WPF 精修篇 自定义控件 自定义控件 因为没有办法对界面可视化编辑 所以用来很少 现在实现的是 自定义控件的 自定义属性 和自定义方法 用VS 创建自定义控件后 会自动创建 Themes 文件 ...

  6. WPF 精修篇 用户控件

    原文:WPF 精修篇 用户控件 增加用户控件 数据绑定还是用依赖属性 使用的事件 就委托注册一下 public delegate void ButtonClick(object b,EventArgs ...

  7. WPF 精修篇 数据绑定到对象

    原文:WPF 精修篇 数据绑定到对象 数据绑定到对象 首先 我们需要一个对象 public class Preson { private string name; public string Name ...

  8. WPF 精修篇 数据绑定 更新通知

    原文:WPF 精修篇 数据绑定 更新通知 开始更新一点有意思的了 首先 数据绑定  其中之一 Element 绑定 看例子 <Window x:Class="WpfApplicatio ...

  9. WPF 精修篇 依赖属性

    原文:WPF 精修篇 依赖属性 依赖属性使用场景 1. 希望可在样式中设置属性. 2. 希望属性支持数据绑定. 3. 希望可使用动态资源引用设置属性. 4. 希望从元素树中的父元素自动继承属性值. 5 ...

随机推荐

  1. InfluxDB(一)初探时序数据库

    初探时序数据库-InfluxDB 最近公司有个需求需要借助InfluxDB实现(或者更准确的说,使用该数据库可以更容易的实现),因此稍微看了下这个数据库,把比较重要的一些东西先简单记录一下,日后如果踩 ...

  2. element-ui 中Switch的用法

    在element-ui中,如果你想知道Switch是开还是关,使用事件 @change="getchange(value2)" 它会输出true或者false.true代表的是开, ...

  3. A:mysql数据库章节导航

    mysql数据库章节导航 mysql5.7的安装(yum和二进制安装) 数据库的基本操作 索引 权限管理 日志管理 逻辑备份mysqldump 物理备份:xtrabackup 主从复制-传统方式 主从 ...

  4. TKinter容器frame使用

    容器frame使用布局 https://www.cnblogs.com/anita-harbour/p/9315472.html TK控件使用大全 https://blog.csdn.net/rng_ ...

  5. 女朋友会 Python 是多么可怕的一件事!

    ​ 阅读文本大概需要 8 分钟. 1 目 标 场 景 女朋友会 Python 是多么可怕的一件事! 一位朋友告诉忽略了一件事,假设女朋友会 Python 的话,那岂不是要翻车?如果是这样的话,女朋友发 ...

  6. Windows10安装ubuntu16.04双系统教程

    写在前面:本教程为windows10安装ubuntu16.04(64位)双系统教程,是我多次安装双系统的经验总结,安装方法同样适用于ubuntu18.04(64位).为了直观和易于理解,我会尽量图文并 ...

  7. HTML5 3D 在智慧物业/地产管理系统中的应用

    概述 该博文主要展示采用 HT for Web 提供的可视化技术,对智慧房产.智慧物业相关方向的可视化呈现做的一点尝试. 传统的 智慧房产/楼宇自动化/智慧物业 常会采用 BIM(建筑信息模型 Bui ...

  8. vue定义data的三种方式与区别

    在vue中,定义data可以有三种写法. 1.第一种写法,对象. var app = new Vue({ el: '#yanggb', data: { yanggb: 'yanggb' } }) 2. ...

  9. GO-逻辑判断(if,else if,else,switch)

    一.if逻辑判断 package main import "fmt" func main() { var a =10; if a>10 { //大括号前不能回车 fmt.Pr ...

  10. idea中tomcat乱码

    idea中tomcat乱码 解决方案: a. file - settings - 搜File Encodings,改为utf-8 b.打开idea工作目录bin,在idea64.exe.vmoptio ...