从文本框中过滤wpf datagrid值

时间:2013-06-13 23:47:00

标签: wpf wpfdatagrid wpf-4.0

我有一个文本框和一个Datagrid。 datagrid有两列名称和电子邮件地址。我想使用文本框中的值过滤datagrid值。enter image description here

1 个答案:

答案 0 :(得分:23)

您可以对ICollectionView DataGrid使用ItemSource,然后您可以应用Filter谓词并在需要时重新列出该列表。

这是一个非常快速的例子。

的Xaml:

<Window x:Class="WpfApplication10.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="MainWindow" Height="188" Width="288" Name="UI" >
    <StackPanel DataContext="{Binding ElementName=UI}">
        <TextBox Text="{Binding FilterString, UpdateSourceTrigger=PropertyChanged}" />
        <DataGrid ItemsSource="{Binding DataGridCollection}" />
    </StackPanel>
</Window>

代码:

namespace WpfApplication10
{
    public partial class MainWindow : Window, INotifyPropertyChanged
    {
        private ICollectionView _dataGridCollection;
        private string _filterString;

        public MainWindow()
        {
            InitializeComponent();
            DataGridCollection = CollectionViewSource.GetDefaultView(TestData);
            DataGridCollection.Filter = new Predicate<object>(Filter);
        }

        public ICollectionView DataGridCollection
        {
            get { return _dataGridCollection; }
            set { _dataGridCollection = value; NotifyPropertyChanged("DataGridCollection"); }
        }

        public string FilterString
        {
            get { return _filterString; }
            set 
            {
                _filterString = value; 
                NotifyPropertyChanged("FilterString");
                FilterCollection();
            }
        }

        private void FilterCollection()
        {
            if (_dataGridCollection != null)
            {
                _dataGridCollection.Refresh();
            }
        }

        public bool Filter(object obj)
        {
            var data = obj as TestClass;
            if (data != null)
            {
                if (!string.IsNullOrEmpty(_filterString))
                {
                    return data.Name.Contains(_filterString) || data.Email.Contains(_filterString);
                }
                return true;
            }
            return false;
        }

        public IEnumerable<TestClass> TestData
        {
            get
            {
                yield return new TestClass { Name = "1", Email = "1@test.com" };
                yield return new TestClass { Name = "2", Email = "2@test.com" };
                yield return new TestClass { Name = "3", Email = "3@test.com" };
                yield return new TestClass { Name = "4", Email = "4@test.com" };
                yield return new TestClass { Name = "5", Email = "5@test.com" };
                yield return new TestClass { Name = "6", Email = "6@test.com" };
                yield return new TestClass { Name = "7", Email = "7@test.com" };
            }
        }

        public event PropertyChangedEventHandler PropertyChanged;
        private void NotifyPropertyChanged(string property)
        {
            if (PropertyChanged != null)
            {
                PropertyChanged(this, new PropertyChangedEventArgs(property));
            }
        }
    }

    public class TestClass
    {
        public string Name { get; set; }
        public string Email { get; set; }
    }
}

结果:

enter image description here enter image description here