1

我有一个应用程序需要显示一组由一些外部条件过滤的行。由于我不会在这里解释的原因,我真的不想从 DataGrid 绑定到的 DataTable 中删除行。为了过滤列表,我折叠了不想显示的行。这很好用,直到用户对 DataGrid 进行排序。排序完成后,折叠的行突然再次可见。我寻找了一个 Sorted 事件,以便我可以重新折叠我需要的行,但只有一个 Sorting 事件。我尝试在每个 DataGridRow 上使用 IsVisibleChanged,但这似乎没有触发。我该如何解决这个问题?

这是问题的简单演示:

public partial class MainWindow : Window
{
    public MainWindow()
    {
        InitializeComponent();

        DataTable table = new DataTable();
        table.Columns.Add("Column 1");

        DataRow row = table.NewRow();
        row[0] = "1";
        table.Rows.Add(row);

        row = table.NewRow();
        row[0] = "2";
        table.Rows.Add(row);

        row = table.NewRow();
        row[0] = "3";
        table.Rows.Add(row);

        _grid.ItemsSource = table.AsDataView();
        _grid.DataContext = table;
        _grid.Loaded += _grid_Loaded;
    }

    void _grid_Loaded(object sender, RoutedEventArgs e)
    {
        var dataGridRow = GetRow(_grid, 1);
        dataGridRow.Visibility = Visibility.Collapsed;

        dataGridRow = GetRow(_grid, 0);
        dataGridRow.Visibility = Visibility.Collapsed;
    }

    public DataGridRow GetRow(DataGrid grid, int index)
    {
        var row = (DataGridRow)grid.ItemContainerGenerator.ContainerFromIndex(index);
        if (row == null)
        {
            // May be virtualized, bring into view and try again.
            grid.UpdateLayout();
            if (grid.Items.Count > index)
            {
                grid.ScrollIntoView(grid.Items[index]);
                row = (DataGridRow)grid.ItemContainerGenerator.ContainerFromIndex(index);
            }
        }
        return row;
    }
}

这是 XAML:

<Window x:Class="WpfApplication1.MainWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="MainWindow" Height="350" Width="525">
<Grid>
    <DataGrid HorizontalAlignment="Left" Margin="54,43,0,0" VerticalAlignment="Top" Height="216" Width="382" Name="_grid"/>

</Grid>

运行程序后,您将看到一个只有数字 3 的 DataGrid。单击​​“列 1”按列排序,注意您现在有数字 1、2 和 3。

任何解决此问题的帮助将不胜感激。

4

1 回答 1

1

我认为您应该专注于过滤 DataTable 而不是 DataGridView。您过去尝试过使用 DataView 吗?您可以使用这些来过滤您的 DataTable,并且由于您有一个绑定的 DataGridView,因此 View 将反映在 GridView 中吗?

通过过滤 DataTable,您不会删除任何行,只是暂时改变它的外观。

这是一个可能有帮助的链接:-

http://msdn.microsoft.com/en-us/library/system.data.dataview.rowfilter.aspx

我希望这有帮助。

于 2012-09-20T16:50:30.977 回答