gpt4 book ai didi

c# - WPF 绑定(bind)按钮到命令

转载 作者:行者123 更新时间:2023-11-30 22:13:56 32 4
gpt4 key购买 nike

我有一个看起来像这样的屏幕:

Screen Snapshot

每个彩色区域都是放入 MainView.xaml 中的不同 UserControl,如下所示:

<UserControl Name="TopDockPanel" DockPanel.Dock="Top" Content="{Binding QuickInfoVM, Source={StaticResource Locator}}" />
<UserControl Name="LeftDockPanel" DockPanel.Dock="Left" Content="{Binding NavigationVM, Source={StaticResource Locator}}" />
<UserControl Name="RightDockPanel" DockPanel.Dock="Right" Content="{Binding MainContentVM, Source={StaticResource Locator}}" />

(我使用的是 MVVMLight,所以 Locator 是 ViewModelLocator)

绿色区域是 ItemsControl 区域,显示每个项目(公司和员工)的按钮:

<UserControl x:Class="MvvmLightDemo.View.NavigationView"
Name="Navigation"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:local="clr-namespace:MvvmLightDemo.View"
mc:Ignorable="d"
d:DesignHeight="300" d:DesignWidth="120"
DataContext="{Binding MainContentVM, Source={StaticResource Locator}}" >

<StackPanel Background="CadetBlue">
<ItemsControl ItemsSource="{Binding PageViewModels}">
<ItemsControl.ItemTemplate>

<ItemContainerTemplate>
<Button Content="{Binding Name}"
Style="{StaticResource NavigationTextStyle}"
Command="{Binding ChangePageCommand, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type local:NavigationView}}}" />


</ItemContainerTemplate>
</ItemsControl.ItemTemplate>
</ItemsControl>
</StackPanel>
</UserControl>

MainContentVM 包含 ChangePageCommand,如下所示:

        public RelayCommand<IPageViewModel> ChangePageCommand
{
get
{
return _changePageCommand = new RelayCommand<IPageViewModel>(
p => ChangeViewModel((IPageViewModel)p),
p => p is IPageViewModel);

}
}

我的问题是,如何将 ItemContainerTemplate 中的按钮绑定(bind)到 MainContentVM 中的 ChangePageCommand?我所拥有的不起作用,在调试时,单击任一按钮时永远不会调用 ChangePageCommand。

当我使用 Command="{Binding ChangePageCommand, RelativeSource={RelativeSource AncestorType={x:Type local:NavigationView}}}" 时,不应该将命令的绑定(bind)设置为NavigationView(DataContext = MainContentVM)?

最佳答案

试试这个:

 <Button Content="{Binding Name}" 
Style="{StaticResource NavigationTextStyle}"
Command="{Binding DataContext.ChangePageCommand, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type local:NavigationView}}}" />

更新:

 <Button Content="{Binding Name}" 
Style="{StaticResource NavigationTextStyle}"
CommandParameter="{Binding}"
Command="{Binding DataContext.ChangePageCommand, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type local:NavigationView}}}" />

关于c# - WPF 绑定(bind)按钮到命令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18766604/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com