通过textBox WPF在DataGrid中搜索

时间:2017-03-15 22:02:36

标签: c# search datagrid textbox grid

我有10-15列的网格。 (我通过datagrid.ItemsSource = myList.ToList()加载数据)另外我有textBox巫婆textChanged事件。当我放在这里,例如。 "猫"我想只看到有价值的行......猫...... 我该怎么做?

2 个答案:

答案 0 :(得分:1)

LINQ查询很适合这种事情,概念是创建一个变量来存储所有行(在示例中称为_animals),然后当用户按下文本框中的键时使用查询,并将结果作为ItemsSource传递。

这是一个如何工作的基本工作示例,首先是Window的XAML。

<Window x:Class="FilterExampleWPF.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:FilterExampleWPF"
        mc:Ignorable="d"
        WindowStartupLocation="CenterScreen"
        Title="MainWindow" Height="350" Width="525">
    <Grid>

        <TextBox x:Name="textBox1" Height="22" Margin="10,10,365,0" VerticalAlignment="Top" KeyUp="textBox1_KeyUp" />
        <DataGrid x:Name="dataGrid1" Height="272" Margin="10,40,10,0" VerticalAlignment="Top" AutoGenerateColumns="True" />

    </Grid>
</Window>

接下来的代码:

using System.Collections.Generic;
using System.Linq;

namespace FilterExampleWPF
{
    public partial class MainWindow : System.Windows.Window
    {
        List<Animal> _animals;

        public MainWindow()
        {
            InitializeComponent();
            _animals = new List<Animal>();
            _animals.Add(new Animal { Type = "cat", Name = "Snowy" });
            _animals.Add(new Animal { Type = "cat", Name = "Toto" });
            _animals.Add(new Animal { Type = "dog", Name = "Oscar" });
            dataGrid1.ItemsSource = _animals;
        }

        private void textBox1_KeyUp(object sender, System.Windows.Input.KeyEventArgs e)
        {
            var filtered = _animals.Where(animal => animal.Type.StartsWith(textBox1.Text));

            dataGrid1.ItemsSource = filtered;            
        }
    }

    public class Animal
    {
        public string Type { get; set; }
        public string Name { get; set; }
    }
}

在本例中,我创建了一个Animal类,但是您可以将其替换为您需要过滤的类。我也启用了AutoGenerateColumns,但是在WPF中添加自己的列绑定仍然可以使用它。

希望这有帮助!

答案 1 :(得分:1)

这是我的解决方法。

public class Animal
    {
        public string Type { get; set; }
        public string Name { get; set; }
    }
    List<Animal> _animals = new List<Animal>();

    public MainWindow()
        {
            InitializeComponent();
            _animals.Add(new Animal { Type = "cat", Name = "Snowy" });
            _animals.Add(new Animal { Type = "cat", Name = "Toto" });
            _animals.Add(new Animal { Type = "dog", Name = "Oscar" });
            dataGrid1.ItemsSource = _animals;
        }
        List<Animal> filterModeLisst = new List<Animal>();

        private void searchBox_TextChanged(object sender, TextChangedEventArgs e)
        {

            filterModeLisst.Clear();

            if (searchBox.Text.Equals(""))
            {
                filterModeLisst.AddRange(_animals);
            } else
            {
                foreach (Animal anim in _animals)
                {

                    if (anim.Name.Contains(searchBox.Text))
                    {
                        filterModeLisst.Add(anim);
                    }
                }
            }

            dataGrid1.ItemsSource = filterModeLisst.ToList();

        }