11

抱歉 - 我的问题几乎与这个相同,但由于它没有得到可行的答案,我希望其他人有一些新的想法。

我有一个绑定到单一类型层次结构的 WPF TreeView:

public class Entity
{
    public string Title { get; set; }
    public ObservableCollection<Entity> Children { get; set; }
}

Entity 类实现了 INotifyPropertyChanged,但为了清楚起见,我省略了这段代码。

TreeView 绑定到 ObservableCollection<Entity> 并且每个 Entity 实例通过其 Children 属性公开一组包含的 Entity 实例:

<TreeView ItemsSource="{Binding Path=Entities}">
    <TreeView.Resources>
        <HierarchicalDataTemplate DataType="{x:Type local:Entity}" ItemsSource="{Binding Path=Children}">
           <TextBlock Text="{Binding Path=Title}" />
        </HierarchicalDataTemplate>
   </TreeView.Resources>
</TreeView>

最初,TreeView 按预期绑定并正确显示多级层次结构。此外,当以编程方式修改某个 Children 集合的成员资格时,更改会正确反映在 TreeView 中。

但是,对根成员级别 ObservableCollection<Entity> 的成员资格的更改不会反映在 TreeView 中。

任何建议,将不胜感激。

谢谢,蒂姆

4

2 回答 2

24

我最初的猜测是,对于根节点,您有如下内容:

public ObservableCollection<Entity> Entities
{
    get;
    set;
}

然后,而不是做一些 [good] 像下面这样:

Entities.Clear();
foreach (var item in someSetOfItems)
    Entities.Add(item);

你正在做这样的事情[坏]:

Entities = new ObservableCollection<Entity>(someSetOfItems);

您应该能够通过创建 Entities 属性的支持字段来追踪问题readonly

private readonly ObservableCollection<Entity> _entities
    = new ObservableCollection<Entity>();

public ObservableCollection<Entity> Entities
{
    get
    {
        return _entities;
    }
}
于 2010-01-26T10:10:36.607 回答
2

进一步的解释,很长时间才能得到答案,但我相信如果你在 XAML 中进行绑定,然后在代码中为属性分配一个新对象,你会破坏绑定,所以你必须在代码中为它重做绑定去工作。因此,具有只读支持字段的解决方案。如果这样做,您将无法分配新的 ObservableCollection,并且您不会通过将新对象分配给支持字段来破坏绑定。

于 2012-03-07T09:46:06.310 回答