wpf - WPF 绑定到 Listview 的 Itemtemplate 的可见性不起作用
问题描述
我正在使用 WPF Prism.Mvvm。我在一侧有一个导航栏,其中包含一个绑定到 Itemssource 的 Listview。这些项目包含图像和内容。现在我的目标是折叠项目的内容,以便我的导航控件只显示图标。
我已经定义了一个可见性绑定,在我的 Listview 之外的一些图像上使用它,它完美地工作。但是,一旦我尝试在 Listview 的 itemtemplate 中的任何内容上使用该精确绑定,什么都不会发生。有趣的是,如果我在没有绑定的情况下将 Visibility 设置为 Collapsed 自己,它会再次起作用。
这是我的看法
<UserControl.Resources>
<ResourceDictionary>
<BooleanToVisibilityConverter x:Key="booleanToVisibilityConverter" />
</ResourceDictionary>
[...]
<DockPanel >
<ContentControl DockPanel.Dock="Top">
<StackPanel>
<Button Margin="5,5,5,5" Style="{StaticResource MyButton}" Command="{Binding ExpandMenuCommand}" Content="Menu" HorizontalAlignment="Left" Width="43.017" />
<ListView BorderThickness="0" VerticalContentAlignment="Top" SelectionMode="Single" ItemsSource="{Binding MenuItems}" SelectedItem="{Binding SelectedItem}" Background="Transparent">
<ListView.ItemTemplate>
<DataTemplate>
<Grid VerticalAlignment="Center">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<Image Margin="0,10,0,10" Grid.Column="0" Source="{Binding ImageSource}" />
<TextBlock Visibility="{Binding Visibility, Converter={StaticResource booleanToVisibilityConverter}}" VerticalAlignment="Center" Margin="10,10,10,10" Grid.Column="1" Text="{Binding Content}" Background="Transparent" FontFamily="Arial" FontWeight="Bold" />
</Grid>
</DataTemplate>
</ListView.ItemTemplate>
</ListView>
</StackPanel>
</ContentControl>
<ContentControl DockPanel.Dock="Bottom">
<Grid>
<Image Visibility="{Binding Visibility, Converter={StaticResource booleanToVisibilityConverter}}" HorizontalAlignment="Center" Height="59" Margin="19,0,0,25" Width="182" Source="/ModuleA;component/Images/Logo.png" VerticalAlignment="Bottom" />
</Grid>
</ContentControl>
</DockPanel>
现在,如果我复制Visibility="{Binding Visibility, Converter={StaticResource booleanToVisibilityConverter}}"
到该 Itemtemplate 上方的任何内容,比如 Listview 本身或 Stackpanel,它的工作原理就像它对 Listview 下的图像所做的那样。但是 Listview.ItemTemplate 中的文本块、图像或网格本身不会响应我的绑定。但是,将其设置为Visibility="Collapsed"
就像我打算的那样工作。
我的视图模型:
private static bool _expanded = true;
private bool _visibility = _expanded;
public bool Visibility
{
get { return _visibility; }
set { SetProperty(ref _visibility, value); }
}
private void ExpandMenu()
{
_expanded = !_expanded;
Visibility = _expanded;
}
解决方案
ListView.ItemTemplate 是 MenuItem 对象的模板。我想Visibility
不是 MenuItem 类的属性,它属于另一个视图模型。所以你需要从不同的DataContext绑定它:
<TextBlock Visibility="{Binding DataContext.Visibility,
Converter={StaticResource booleanToVisibilityConverter},
RelativeSource={RelativeSource AncestorType=ListView}}"
VerticalAlignment="Center"
Margin="10,10,10,10" Grid.Column="1"
Text="{Binding Content}"
Background="Transparent"
FontFamily="Arial"
FontWeight="Bold" />
推荐阅读
- reactjs - React 不会在 redux 存储更改时重新渲染地图功能(使用 MaterializeCss 选择选项)
- git - GIT - 如何撤消丢弃的提交
- amcharts - 在 xy 图表 amcharts 中为每个图寻找单个工具提示
- python - 在python函数中返回多个值
- .htaccess - .htaccess RewriteRule 查询字符串
- c# - 使用 BigInteger 的 C# 字节数组计算无法正常工作
- python - Plotly 中的 Choropleth 地图:颜色显示不正确
- docker - 谷歌云身份验证 json 密钥文件
- angular - 在 Angular 中从单个服务提供不同的数据还是应该为不同的数据创建单独的服务是好的?
- javascript - 目录和子目录中的 node.js 文件搜索