使用xaml绑定和视图模型执行带有参数的命令

本文关键字:行带 参数 命令 执行 模型 xaml 绑定 视图 使用 | 更新日期: 2023-09-27 17:54:14

目前我在xaml:

<ItemsControl ItemsSource="{Binding Facilities, Mode=OneWay}">
 <ItemsControl.ItemTemplate>
  <DataTemplate>
   <Border Style="{StaticResource BorderStyleHeader}">
    <Grid>
     <Grid.RowDefinitions>
      <RowDefinition Height="33" />
      <RowDefinition Height="33" />
     </Grid.RowDefinitions>
     <Grid.ColumnDefinitions>
      <ColumnDefinition Width="150" />
      <ColumnDefinition Width="*" />
     </Grid.ColumnDefinitions>
     <TextBlock Text="{Binding Name}" HorizontalAlignment="Center" Grid.Row="0" Grid.Column="1" FontWeight="Bold" />
     <TextBlock Text="{Binding Description}" Grid.Row="1" Grid.Column="1" />
     <Button Content="Reserveer Nu" Style="{StaticResource ButtonStyle}" 
             Margin="5" Grid.Row="1" Grid.Column="0" 
             Command="{Binding Reservation.ItemClicked}" 
             CommandParameter="{Binding FacilityId}"/>
    </Grid>
   </Border>
  </DataTemplate>
 </ItemsControl.ItemTemplate>
</ItemsControl>

现在第一件事是,我希望按钮在我的视图模型

中引发事件
public RelayCommand ItemClicked
{
    get
    {
        return new RelayCommand(() =>
        {
            MessageBox.Show("Something is clicked");
        });
    }
}

但它拒绝…
其次,我希望能够用参数引发事件(注意命令参数),但我从未使用过它,因此我不知道如何使用它。

我的问题是:

  1. 为什么我的relaycommand没有被执行?

  2. 如何使用命令参数?

使用xaml绑定和视图模型执行带有参数的命令

为什么我的relaycommand没有被执行?
如何使用命令参数?

如果你正在使用Josh Smith文章中的RelayCommand类,那么这两个问题的答案是相同的…构造函数接受Action<object>,而不是Action。所以你的代码应该是:

    return new RelayCommand((param) =>
    {
        MessageBox.Show("Something is clicked - Parameter value = " + param);
    });

编辑:好的,所以你正在使用来自MVVM Light的RelayCommand…这个类有两个版本,一个是通用的,一个不是。非泛型版本不接受参数,因此需要泛型版本。您的命令应该像这样:

public RelayCommand<int> ItemClicked
{
    get
    {
        return new RelayCommand<int>((i) =>
        {
            MessageBox.Show("Something is clicked - Parameter value is " + i);
        });
    }
}

(假设参数类型为int)

至于为什么你现在的代码不工作,我不能回答没有额外的信息…