假设您有一个用户选择列表。根据用户的选择,其他选项可能不再可用。
我有一个ValueConverter可以处理这个问题。如果它知道哪些选择已经被做出,它将返回一个值,指示正在转换的项目是否仍然可选择。
问题是唯一知道用户选择的地方在于此屏幕的ViewModel中。没问题,我会将转换器作为ViewModel的属性,并在转换器的构造函数中传递对ViewModel的引用,以便转换器随时可以检查所选项目的列表。
现在我遇到的问题是似乎它并没有实际执行任何转换。
简化一下: ViewModel有一个名为MySelectionConverter的属性,类型为IValueConverter。 ViewModel有一个所选项目列表。 在视图(类型为继承自UserControl的MyScreen)中,有一个带有项目的列表框。
ItemTemplate看起来像这样:
我有一个ValueConverter可以处理这个问题。如果它知道哪些选择已经被做出,它将返回一个值,指示正在转换的项目是否仍然可选择。
问题是唯一知道用户选择的地方在于此屏幕的ViewModel中。没问题,我会将转换器作为ViewModel的属性,并在转换器的构造函数中传递对ViewModel的引用,以便转换器随时可以检查所选项目的列表。
现在我遇到的问题是似乎它并没有实际执行任何转换。
简化一下: ViewModel有一个名为MySelectionConverter的属性,类型为IValueConverter。 ViewModel有一个所选项目列表。 在视图(类型为继承自UserControl的MyScreen)中,有一个带有项目的列表框。
ItemTemplate看起来像这样:
<ListBox.ItemTemplate>
<DataTemplate>
<Grid Height="Auto" Width="100" VerticalAlignment="Top" Visibility="{Binding Path=DataContext.MySelectionConverter, RelativeSource={RelativeSource AncestorType={x:Type MyScreen}}}">
<TextBlock Text="The user might want to select me." />
</Grid>
</DataTemplate>
</ListBox.ItemTemplate>
我怀疑我的绑定出了问题。但也可能根本做不到这一点。非常感谢您的帮助。
编辑: 根据我目前获得的信息,我的绑定是不正确的。但事实证明,我无法做到我想做的事情。本质上,我试图使用绑定来设置转换器:
Visibility="{Binding Converter={Binding Path=DataContext.StyleOptionConverter, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type local:StyleSelectionScreen}}}}
Visual Studio告诉我:
无法在类型为“Binding”的“Converter”属性上设置“绑定”。只能在DependencyObject的DependencyProperty上设置“绑定”。
因此,现在我猜问题变成了:我该如何解决这个问题?我需要一个转换器,它知道将要使用它的屏幕的ViewModel的状态。