DataGrid中的Silverlight DataGridRows-如何有选择地隐藏它们?

DataGrid中的Silverlight DataGridRows-如何有选择地隐藏它们?,silverlight,datagrid,Silverlight,Datagrid,我有一个ObservableCollection,它提供了一个更新良好的数据网格 要点:我想过滤(折叠)行,而不将它们从集合中移除 有没有办法做到这一点,或者像普通的.Net一样在网格上放置一个视图?我刚刚介绍过 这篇文章附带了一个简单的演示应用程序,它演示了如何实现你想要的 该解决方案应具有足够的通用性,以便可重用,并基于以下自定义扩展方法: public static class Extensions { /// <summary> /// Applies an

我有一个ObservableCollection,它提供了一个更新良好的数据网格

要点:我想过滤(折叠)行,而不将它们从集合中移除

有没有办法做到这一点,或者像普通的.Net一样在网格上放置一个视图?

我刚刚介绍过

这篇文章附带了一个简单的演示应用程序,它演示了如何实现你想要的

该解决方案应具有足够的通用性,以便可重用,并基于以下自定义扩展方法:

public static class Extensions
{
    /// <summary>
    /// Applies an action to each item in the sequence, which action depends on the evaluation of the predicate.
    /// </summary>
    /// <typeparam name="TSource">The type of the elements of source.</typeparam>
    /// <param name="source">A sequence to filter.</param>
    /// <param name="predicate">A function to test each element for a condition.</param>
    /// <param name="posAction">An action used to mutate elements that match the predicate's condition.</param>
    /// <param name="negAction">An action used to mutate elements that do not match the predicate's condition.</param>
    /// <returns>The elements in the sequence that matched the predicate's condition and were transformed by posAction.</returns>
    public static IEnumerable<TSource> ApplyMutateFilter<TSource>(this IEnumerable<TSource> source,
                                                                  Func<TSource, bool> predicate,
                                                                  Action<TSource> posAction,
                                                                  Action<TSource> negAction)
    {
        if (source != null)
        {
            foreach (TSource item in source)
            {
                if (predicate(item))
                {
                    posAction(item);
                }
                else
                {
                    negAction(item);
                }
            }
        }

        return source.Where(predicate);
    }
}
公共静态类扩展
{
/// 
///将操作应用于序列中的每个项,该操作取决于谓词的计算。
/// 
///源的元素的类型。
///要过滤的序列。
///测试每个元素的条件的函数。
///用于改变与谓词条件匹配的元素的操作。
///用于改变与谓词条件不匹配的元素的操作。
///序列中匹配谓词条件并通过posAction转换的元素。
公共静态IEnumerable ApplyMutateFilter(此IEnumerable源,
Func谓词,
行动,行动,
行动(无行动)
{
如果(源!=null)
{
foreach(源中的TSource项)
{
if(谓语(项))
{
行动(项目);
}
其他的
{
负作用(项目);
}
}
}
返回source.Where(谓词);
}
}

如果您在可观察集合的顶部有一个视图,您可以实现这一点。我写了一篇关于过滤Silverlight数据网格的文章。您有一个FilteredCollectionView,可以在其中添加任何IFilter。以下是文章的链接:

希望对你有帮助